using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace LYFZ.Software.MainBusiness.SMSManagement.ShortSmsMessage { public partial class FrmHigehrSelect : LYFZ.Software.UI.SMSManagement.ShortSmsMessage.FrmHigehrSelect { public FrmHigehrSelect() { this.Shown += FrmHigehrSelect_Shown; this.btnOk.Click += btnOk_Click; this.btnCanle.Click += btnCanle_Click; this.rdoAll.Click += rdoAll_Click; this.rdoHunsa.Click += rdoHunsa_Click; this.rdoErtong.Click += rdoErtong_Click; this.rdoXiezheng.Click += rdoXiezheng_Click; this.rdoqita.Click += rdoqita_Click; BindCategory(); SetGrpEnabled(-1); this.rdoanshenri.Click += rdoanshenri_Click; this.rdoanhungqi.Click += rdoanhungqi_Click; CurrentBusinessType = LYFZ.Software.MainBusiness.CommonLogical.SuccessfulLogin.GetBusinessType(); SetShowSmsTpye(); } /// /// 当前软件业务类型 /// LYFZ.Software.MainBusiness.EnumPermissions.BusinessType CurrentBusinessType = EnumPermissions.BusinessType.旗舰版; /// /// 根据软件业务版本设置显示客户类型 /// void SetShowSmsTpye() { switch (CurrentBusinessType) { case EnumPermissions.BusinessType.婚纱版: this.rdoErtong.Visible = false; break; case EnumPermissions.BusinessType.儿童版: this.rdoHunsa.Visible = false; break; } } void rdoanhungqi_Click(object sender, EventArgs e) { this.grpNianLing.Enabled = false; this.numShuiA.Value=0; this.numShuiZ.Value=0; this.numTianA.Value = 0; this.numTianZ.Value = 0; } void rdoanshenri_Click(object sender, EventArgs e) { this.grpNianLing.Enabled = true; } SQueryObject currentQueryObject = new SQueryObject(); /// /// 当前查询对象 /// public SQueryObject CurrentQueryObject { get { return currentQueryObject; } set { currentQueryObject = value; } } void rdoqita_Click(object sender, EventArgs e) { SetGrpEnabled(Convert.ToInt32(rdoqita.Tag)); } void rdoXiezheng_Click(object sender, EventArgs e) { SetGrpEnabled(Convert.ToInt32(rdoXiezheng.Tag)); } void rdoErtong_Click(object sender, EventArgs e) { SetGrpEnabled(Convert.ToInt32(rdoErtong.Tag)); } void rdoHunsa_Click(object sender, EventArgs e) { SetGrpEnabled(Convert.ToInt32(rdoHunsa.Tag)); } void rdoAll_Click(object sender, EventArgs e) { SetGrpEnabled(Convert.ToInt32(rdoAll.Tag)); } void SetGrpEnabled(int type) { if (type < 0) { this.grpJilianri.Enabled = false; this.grpNianLing.Enabled = false; this.rdoanhungqi.Visible = false; this.cmbAnhungqi.Visible = false; this.numShuiA.Value = 0; this.numShuiZ.Value = 0; this.numTianA.Value = 0; this.numTianZ.Value = 0; this.cmbAnshenri.SelectedItem = PressMemorialDay.不限.ToString(); this.cmbAnhungqi.SelectedItem = PressMemorialDay.不限.ToString(); } else { this.grpJilianri.Enabled = true; this.grpNianLing.Enabled = true; if (type == 0) { this.rdoanhungqi.Visible = true; this.cmbAnhungqi.Visible = true; } else { this.rdoanhungqi.Visible = false; this.cmbAnhungqi.Visible = false; } } this.CurrentQueryObject.QCustomerType = (SQueryCustomerType)type; if (this.CurrentQueryObject.QCustomerType != SQueryCustomerType.婚纱客户) { this.rdoanshenri.Checked = true; this.cmbAnhungqi.SelectedItem = PressMemorialDay.不限.ToString(); } } public string Pak_PackagesClass; public string Price1; public string Price2; LYFZ.BLL.BLL_ErpSystemCategory scbll = new BLL.BLL_ErpSystemCategory(); void BindCategory() { try { #region 套系类别 LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_PackagesCategoryAndName(this.CtvPak_PackagesClass, "AAAAAAB", true); this.CtvPak_PackagesClass.IsSelectParentNode = true; #endregion #region 订单类别 LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_SystemCategory("BFAGAHBFDGCABAJIH", this.cmbtreevOrdeClass, true); this.cmbtreevOrdeClass.IsSelectParentNode = true; #endregion #region 客户来源 LYFZ.Software.MainBusiness.DoorCityProcess.PublicCodeClasses.BindComboBoxTreeView_SystemCategory("AAAAAAF", this.cmbtreevCustomerSource, true); this.cmbtreevCustomerSource.IsSelectParentNode = true; #endregion #region 客户地区 DataTable tbl = new DataTable(); tbl = scbll.GetList(" Sc_ClassParentID = '" + scbll.GetList("Sc_ClassCode='AAAAAAC'").Tables[0].Rows[0]["ID"].ToString().Trim() + "'").Tables[0]; this.cmbCus_Region.Items.Add(""); if (tbl.Rows.Count > 0) { for (int i = 0; i < tbl.Rows.Count; i++) { this.cmbCus_Region.Items.Add(tbl.Rows[i]["Sc_ClassName"].ToString().Trim()); } } #endregion this.cmbAnshenri.DataSource = Enum.GetNames(typeof(PressMemorialDay)); this.cmbAnhungqi.DataSource = Enum.GetNames(typeof(PressMemorialDay)); } catch (Exception ex) { MessageBoxCustom.Show(ex.Message); } } #region 加载 protected void FrmHigehrSelect_Shown(object sender, EventArgs e) { } #endregion #region 取消 protected void btnCanle_Click(object sender, EventArgs e) { this.Close(); } #endregion /// /// 获取查询表名 /// /// string GetSQueryTableName() { string tableName = "Vw_OrderCustomerList";//Vw_PersonalCustomerList if (this.grpJilianri.Enabled) { if (this.CurrentQueryObject.QCustomerType == SQueryCustomerType.婚纱客户 || this.CurrentQueryObject.QCustomerType == SQueryCustomerType.写真客户 || this.CurrentQueryObject.QCustomerType == SQueryCustomerType.其它客户) { if ( (this.rdoanshenri.Checked && GetPressMemorialDay(this.cmbAnshenri.Text) != PressMemorialDay.不限) || (this.rdoanshui.Checked && this.numShuiZ.Value > 0 && this.numShuiA.Value <= this.numShuiZ.Value) || (this.rdoantian.Checked && this.numTianZ.Value > 0 && this.numTianA.Value <= this.numTianZ.Value) || this.cmbCus_Region.Text.Trim().Length>0 ) { tableName = "Vw_PersonalCustomerList"; } } } return tableName; } /// /// 获取查询条件语句 /// /// string GetQueryWhereString() { string retWhereString = "1=1 "; //套系类别 string Ord_PhotographyCategory = GetPackagesClass(this.CtvPak_PackagesClass.TreeView.SelectedNode); //套系名称 string Ord_SeriesName = GetPackagesName(this.CtvPak_PackagesClass.TreeView.SelectedNode); //订单类别 string Ord_OrderClass = GetTreeNodeAllNode(this.cmbtreevOrdeClass.TreeView.SelectedNode); //客户来源 string Ord_CustomerSource = GetTreeNodeAllNode(this.cmbtreevCustomerSource.TreeView.SelectedNode); if (Ord_PhotographyCategory.Trim().Length > 0) { retWhereString += " and (Ord_PhotographyCategory='" + Ord_PhotographyCategory.Replace(",", "' or Ord_PhotographyCategory = '") + "')"; } if (Ord_SeriesName.Trim().Length > 0) { retWhereString += " and (Ord_SeriesName='" + Ord_SeriesName.Trim() + "')"; } if (Ord_OrderClass.Trim().Length > 0) { retWhereString += " and (Ord_OrderClass='" + Ord_OrderClass.Replace(",", "' or Ord_OrderClass = '") + "')"; } if (Ord_CustomerSource.Trim().Length > 0) { retWhereString += " and (Ord_CustomerSource='" + Ord_CustomerSource.Replace(",", "' or Ord_CustomerSource = '") + "')"; } switch (this.CurrentQueryObject.QCustomerType) { case SQueryCustomerType.婚纱客户: retWhereString += " and Ord_Type='0' "; break; case SQueryCustomerType.儿童客户: retWhereString += " and Ord_Type='1' "; break; case SQueryCustomerType.写真客户: retWhereString += " and (Ord_Type='2')"; break; case SQueryCustomerType.其它客户: retWhereString += " and (Ord_Type='3')"; break; } if (this.cmbCus_Region.Text.Trim().Length > 0) { retWhereString += " and (Cus_Region like '%" + this.cmbCus_Region.Text.Trim() + "%')"; } //消费金额 yingFuPrice // int yingFuPrice = this.numTaoxijiageA.Value; if (this.numTaoxijiageZ.Value > 0 && this.numTaoxijiageA.Value <= this.numTaoxijiageZ.Value) { retWhereString += " and (yingFuPrice>=" +Convert.ToInt32(this.numTaoxijiageA.Value).ToString() + " and yingFuPrice<=" + Convert.ToInt32(this.numTaoxijiageZ.Value).ToString() + ") "; } //预约时间的起始时间 DateTime appointmentTimeA = LYFZ.WinAPI.CustomPublicMethod.GetNullDateTime(); //预约时间的结束时间 DateTime appointmentTimeZ = LYFZ.WinAPI.CustomPublicMethod.GetNullDateTime(); DateTime.TryParse(this.txtyuyueshijianA.Text.Trim(), out appointmentTimeA); DateTime.TryParse(this.txtyuyueshijianZ.Text.Trim(), out appointmentTimeZ); if (appointmentTimeZ>LYFZ.WinAPI.CustomPublicMethod.GetNullDateTime()&&appointmentTimeA <= appointmentTimeZ) { retWhereString += " and (Ord_CreateDateTime>='" + appointmentTimeA.ToString("yyyy-MM-dd") + "' and Ord_CreateDateTime<='" + appointmentTimeZ.ToString("yyyy-MM-dd") + "') "; } if (this.grpJilianri.Enabled) { PressMemorialDay anShenri=(PressMemorialDay)Enum.Parse(typeof(PressMemorialDay),this.cmbAnshenri.Text); int day = (int)anShenri; if (this.rdoanshenri.Checked && anShenri!= PressMemorialDay.不限) { if (anShenri == PressMemorialDay.今天) { retWhereString += " and GregorianCalendar_NowYearBirthday ='" + SDateTime.Now.ToString("yyyy-MM-dd") + "' "; } else { retWhereString += " and (GregorianCalendar_NowYearBirthday >='" + SDateTime.Now.ToString("yyyy-MM-dd") + "' and GregorianCalendar_NowYearBirthday<='" + SDateTime.Now.AddDays(day).ToString("yyyy-MM-dd") + "') "; } } PressMemorialDay anHunQi = (PressMemorialDay)Enum.Parse(typeof(PressMemorialDay), this.cmbAnhungqi.Text); int hqiday = (int)anHunQi; if (this.rdoanhungqi.Checked && this.rdoanhungqi.Visible && anHunQi != PressMemorialDay.不限) { if (anHunQi == PressMemorialDay.今天) { retWhereString += " and GregorianCalendar_NowYearDayForMarriage ='" + SDateTime.Now.ToString("yyyy-MM-dd") + "' "; } else { retWhereString += " and (GregorianCalendar_NowYearDayForMarriage >='" + SDateTime.Now.ToString("yyyy-MM-dd") + "' and GregorianCalendar_NowYearDayForMarriage<='" + SDateTime.Now.AddDays(hqiday).ToString("yyyy-MM-dd") + "') "; } } } if (this.grpNianLing.Enabled) { if (this.rdoanshui.Checked && this.numShuiZ.Value > 0 && this.numShuiA.Value <= this.numShuiZ.Value) { retWhereString += " and (Age_Year>=" + Convert.ToInt32(this.numShuiA.Value).ToString() + " and Age_Year<=" + Convert.ToInt32(this.numShuiZ.Value).ToString() + ") "; } else if (this.rdoantian.Checked && this.numTianZ.Value > 0 && this.numTianA.Value <= this.numTianZ.Value) { retWhereString += " and (Age_Day>=" + Convert.ToInt32(this.numTianA.Value).ToString() + " and Age_Day<=" + Convert.ToInt32(this.numTianZ.Value).ToString() + ") "; } } return retWhereString; } /// /// 获取当前节点和所有子节点值 /// /// /// string GetTreeNodeAllNode(TreeNode node) { string ret = ""; if (node != null) { ret = node.Text.Trim(); if (node.Nodes.Count > 0) { foreach (TreeNode n in node.Nodes) { ret += "," + GetPackagesClass(n); } } } return ret.Trim().Trim(','); } /// /// 获取套系类别 /// /// string GetPackagesClass(TreeNode node) { string ret = ""; if (node != null) { if (node.Name.Trim() == "true") { ret = node.Text.Trim(); if (node.Nodes.Count > 0) { foreach (TreeNode n in node.Nodes) { if (n.Name.Trim() == "true") ret += "," + GetPackagesClass(n); } } } } return ret.Trim().Trim(','); } /// /// 获取套系名称 /// /// string GetPackagesName(TreeNode node) { string ret = ""; if (node != null) { if (node.Name.Trim() != "true") { ret = node.Text.Trim(); } } return ret.Trim(); } /// /// 获取纪念日 /// /// /// PressMemorialDay GetPressMemorialDay(string text) { return (PressMemorialDay)Enum.Parse(typeof(PressMemorialDay), text); } #region 确定 protected void btnOk_Click(object sender, EventArgs e) { // this.CurrentQueryObject(Vw_OrderCustomerList) if (this.numTaoxijiageA.Value > this.numTaoxijiageZ.Value) { MessageBoxCustom.Show("消费金额的起始值不能大于结束值"); return; } //预约时间的起始时间 DateTime appointmentTimeA=LYFZ.WinAPI.CustomPublicMethod.GetNullDateTime(); //预约时间的结束时间 DateTime appointmentTimeZ = LYFZ.WinAPI.CustomPublicMethod.GetNullDateTime(); if (this.txtyuyueshijianA.Text.Trim().Length>0&&!DateTime.TryParse(this.txtyuyueshijianA.Text.Trim(), out appointmentTimeA)) { MessageBoxCustom.Show("预约时间的起始时间格式不正确"); return; } if (this.txtyuyueshijianZ.Text.Trim().Length > 0 && !DateTime.TryParse(this.txtyuyueshijianZ.Text.Trim(), out appointmentTimeZ)) { MessageBoxCustom.Show("预约时间的结束时间格式不正确"); return; } if (appointmentTimeA > appointmentTimeZ) { MessageBoxCustom.Show("预约时间的起始时间不能大于结束时间"); return; } if (this.grpNianLing.Enabled) { if (this.rdoanshui.Checked) { if (this.numShuiA.Value > this.numShuiZ.Value) { MessageBoxCustom.Show("年龄起始值不能大于结束值"); return; } } else if (this.rdoantian.Checked) { if (this.numTianA.Value > this.numTianA.Value) { MessageBoxCustom.Show("起始天数不能大于结束天数"); return; } } } this.CurrentQueryObject.SQueryTableName = GetSQueryTableName(); this.CurrentQueryObject.SQueryWhereString = GetQueryWhereString(); // MessageBoxCustom.Show(this.CurrentQueryObject.SQueryWhereString); this.DialogResult = System.Windows.Forms.DialogResult.OK; } #endregion } /// /// 按纪念日 /// public enum PressMemorialDay { 不限=-1, 今天=0, 近两天=2, 近三天 = 3, 近五天 = 5, 近七天 = 7, 近十天 = 10, 近十五天 = 15, 近一个月 = 30, 近三个月 = 90, 近半年 = 180, } /// /// 查询客户类型 /// public enum SQueryCustomerType { 全部=-1, 婚纱客户=0, 儿童客户=1, 写真客户=2, 其它客户 = 3 } /// /// 查询对象 /// public class SQueryObject { public SQueryObject() { } string _SQueryTableName = ""; /// /// 查询表名 /// public string SQueryTableName { get { return _SQueryTableName; } set { _SQueryTableName = value; } } string _SQueryWhereString = ""; /// /// 查询条件语句 /// public string SQueryWhereString { get { return _SQueryWhereString; } set { _SQueryWhereString = value; } } SQueryCustomerType _QCustomerType = SQueryCustomerType.全部; /// /// 查询的客户类型 /// public SQueryCustomerType QCustomerType { get { return _QCustomerType; } set { _QCustomerType = value; } } } }