/// <summary> /// 商品咨询管理员回复 /// </summary> /// <param name="model"></param> public static void Push_askreply(Lebi_Comment model) { BaseConfig conf = ShopCache.GetBaseConfig(); if (conf.APPPush_sendmode.Contains("ask")) { Lebi_User user = B_Lebi_User.GetModel(model.User_id); if (user.Language == "") { user.Language = Language.Languages().FirstOrDefault().Code; } string content = Language.Content(conf.SMSTPL_ask, user.Language); content = ReplaceSMSTag(content, user, conf); content = content.Replace("{$Content}", model.Content); Push(user.Device_system, user.Device_id, content); } }
/// <summary> /// 商品咨询管理员回复 /// </summary> /// <param name="model"></param> public static void SendSMS_askreply(Lebi_Comment model) { BaseConfig conf = ShopCache.GetBaseConfig(); if (conf.SMS_sendmode.Contains("SMSTPL_ask")) { Lebi_User user = B_Lebi_User.GetModel(model.User_id); if (user.Language == "") { user.Language = Language.Languages().FirstOrDefault().Code; } string content = Language.Content(conf.SMSTPL_ask, user.Language); content = ReplaceSMSTag(content, user, conf); content = content.Replace("{$Content}", model.Content); Send(user.MobilePhone, content); } }
/// <summary> /// 使一个购买单的佣金生效 /// 完结订单时使用 /// </summary> /// <param name="order"></param> public void AgentMoneyOK() { //string sql = "update Lebi_Agent_Money set Type_id_AgentMoneyType=382 where Order_id=" + order.id + ""; //Common.ExecuteSql(sql); List <Lebi_Agent_Money> models = B_Lebi_Agent_Money.GetList("Order_id=" + Order.id + "", ""); foreach (Lebi_Agent_Money model in models) { model.Type_id_AgentMoneyStatus = 382; Lebi_User user = B_Lebi_User.GetModel(model.User_id); if (user != null) { UpdateUserMoney(user, model); B_Lebi_Agent_Money.Update(model); } } }
public Agent(Lebi_Order order) { bc = ShopCache.GetBaseConfig(); if (bc.IsUsedAgent == "1") { UsedAgent = true; } if (bc.IsUsedAgent_Area == "1") { UsedAgentArea = true; } if (bc.IsUsedAgent_Product == "1") { UsedAgentProduct = true; } Order = order; OrderUser = B_Lebi_User.GetModel(order.User_id); //EndDays = Convert.ToInt32(bc.AgentEndDays); }
/// <summary> /// 留言反馈 /// </summary> /// <param name="model"></param> public static void SendSMS_inquiry(Lebi_Inquiry model) { BaseConfig conf = ShopCache.GetBaseConfig(); if (conf.SMS_sendmode.Contains("SMSTPL_Admin_inquiry")) { Lebi_User user = B_Lebi_User.GetModel(0); if (user == null) { user = new Lebi_User(); } string list = "" + Language.Tag("昵称", model.Language) + ":" + model.UserName + "<br />" + Language.Tag("电话", model.Language) + ":" + model.Phone + "<br />" + Language.Tag("EMAIL", model.Language) + ":" + model.Email + "<br />" + Language.Tag("标题", model.Language) + ":" + model.Subject + "<br />" + Language.Tag("内容", model.Language) + ":" + model.Content + "<br />" + Language.Tag("时间", model.Language) + ":" + model.Time_Add + ""; string Admin_content = Language.Content(conf.SMSTPL_Admin_inquiry, model.Language); Admin_content = ReplaceSMSTag(Admin_content, user, conf); Admin_content = Admin_content.Replace("{$Title}", model.Subject); Admin_content = Admin_content.Replace("{$Content}", list); Send(conf.SMS_reciveno, Admin_content); } }
protected override void LoadPage(string themecode, int siteid, string languagecode, string pcode) { if (!Shop.Bussiness.B_API.Check("plugin_agent")) { Response.Write(Tag("权限不足")); Response.End(); } if (CurrentUser.id == 0) { Response.Redirect(URL("P_Login", "" + HttpUtility.UrlEncode(RequestTool.GetRequestUrlNonDomain()) + "," + GetUrlToken(RequestTool.GetRequestUrlNonDomain()) + "")); } LoadTheme(themecode, siteid, languagecode, pcode); path = "<a href=\"" + URL("P_Index", "") + "\" class=\"home\" title=\"" + Tag("首页") + "\"><span>" + Tag("首页") + "</span></a><em class=\"home\">»</em><a href=\"" + URL("P_UserCenter", "") + "\"><span>" + Tag("会员中心") + "</span></a><em>»</em><a class=\"text\"><span>" + Tag("推广佣金") + "</span></a>"; string money_ = Common.GetValue("select sum(Money) from Lebi_Agent_Money where User_id=" + CurrentUser.id + " and Type_id_AgentMoneyStatus=382 and datediff(d,Time_add,'" + System.DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss") + "')>" + SYS.CommissionMoneyDays + ""); decimal.TryParse(money_, out money); UserCount = B_Lebi_User.Counts("User_id_parent=" + CurrentUser.id + ""); UserCountmonth = B_Lebi_User.Counts("User_id_parent=" + CurrentUser.id + " and Time_Reg>'" + System.DateTime.Now.Date.AddDays(0 - System.DateTime.Now.Day).ToString("yyyy-MM-dd") + "'"); UserCountday = B_Lebi_User.Counts("User_id_parent=" + CurrentUser.id + " and Time_Reg>'" + System.DateTime.Now.Date.ToString("yyyy-MM-dd") + "'"); }
/// <summary> /// 使一个购买单的佣金失效 /// 已完结订单取消完结时使用 /// </summary> /// <param name="order"></param> public void AgentMoneyCancal() { //string sql = "update Lebi_Agent_Money set Type_id_AgentMoneyType=383 where Order_id=" + order.id + ""; //Common.ExecuteSql(sql); List <Lebi_Agent_Money> models = B_Lebi_Agent_Money.GetList("Order_id=" + Order.id + "", ""); foreach (Lebi_Agent_Money model in models) { model.Type_id_AgentMoneyStatus = 381; Lebi_User user = B_Lebi_User.GetModel(model.User_id); if (user != null) { B_Lebi_Agent_Money.Update(model); user.AgentMoney_history -= model.Money; user.AgentMoney -= model.Money; B_Lebi_User.Update(user); //model.Money = 0 - model.Money; //UpdateUserMoney(user, model); } } }
/// <summary> /// 处理地区代理佣金 /// </summary> private void AgentAreaMoney() { if (Order.T_Area_id > 0) { Lebi_Agent_Area agentarea = GetAgentArea(Order.T_Area_id); if (agentarea != null) { if (agentarea.Time_end.Date > System.DateTime.Now.Date) { Lebi_User user = B_Lebi_User.GetModel(agentarea.User_id); if (user != null) { //按籍贯的佣金 decimal yongjin = agentarea.Commission_1; decimal money = Order.Money_Product * yongjin / 100; AddMoney(money, user, 393, agentarea.Area_id, 0, 0); } } } } if (OrderUser.Area_id > 0) { Lebi_Agent_Area agentarea = GetAgentArea(OrderUser.Area_id); if (agentarea != null) { if (agentarea.Time_end.Date > System.DateTime.Now.Date) { Lebi_User user = B_Lebi_User.GetModel(agentarea.User_id); if (user != null) { //按籍贯的佣金 decimal yongjin = agentarea.Commission_2; decimal money = Order.Money_Product * yongjin / 100; AddMoney(money, user, 394, agentarea.Area_id, 0, 0); } } } } }
/// <summary> /// 站内信管理员回复 /// </summary> /// <param name="user"></param> public static void Push_messagereply(Lebi_Message model) { BaseConfig conf = ShopCache.GetBaseConfig(); if (conf.APPPush_sendmode.Contains("message")) { Lebi_User user = B_Lebi_User.GetModel(model.User_id_To); if (user == null) { user.Language = Language.Languages().FirstOrDefault().Code; } if (user.Language == "") { user.Language = Language.Languages().FirstOrDefault().Code; } string content = Language.Content(conf.SMSTPL_message, user.Language); content = ReplaceSMSTag(content, user, conf); content = content.Replace("{$Title}", model.Title); content = content.Replace("{$Content}", model.Content); Push(user.Device_system, user.Device_id, content); } }
/// <summary> /// 单品代理佣金 /// </summary> private void AgentProductMoney() { List <Lebi_Order_Product> Products = B_Lebi_Order_Product.GetList("Order_id=" + Order.id + "", ""); if (Products == null) { return; } int pid = 0; decimal money = 0; Lebi_Agent_Product_User auser; foreach (Lebi_Order_Product model in Products) { Lebi_Product pro = B_Lebi_Product.GetModel(model.Product_id); pid = pro.Product_id == 0 ? pro.id : pro.Product_id; Lebi_Agent_Product apro = B_Lebi_Agent_Product.GetModel("Product_id=" + pid + ""); if (apro == null) { continue; } auser = B_Lebi_Agent_Product_User.GetModel("User_id=" + apro.User_id + " and IsFailure=0"); if (auser == null) { continue; } if (auser.Time_end.Date < System.DateTime.Now.Date) { continue; } Lebi_User user = B_Lebi_User.GetModel(apro.User_id); if (user == null) { continue; } money = model.Price * model.Count * auser.Commission / 100; AddMoney(money, user, 392, 0, model.Product_id, pid, pro.Number); } }
public static Model Info(Lebi_User user) { BaseConfig bc = ShopCache.GetBaseConfig(); Model m = new Model(); decimal Money = 0; string money_ = Common.GetValue("select sum(Money) from Lebi_Agent_Money where User_id=" + user.id + " and Type_id_AgentMoneyStatus=382 and datediff(d,Time_add,'" + System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "')>" + bc.CommissionMoneyDays + ""); decimal.TryParse(money_, out Money); int UserCount = 0; UserCount = B_Lebi_User.Counts("User_id_parent=" + user.id + ""); int UserCountmonth = 0; UserCountmonth = B_Lebi_User.Counts("User_id_parent=" + user.id + " and (datediff(d,Time_Reg,'" + System.DateTime.Now.Date.AddDays(0 - System.DateTime.Now.Day + 1).ToString("yyyy-MM-dd") + "')<=0 and datediff(d,Time_Reg,'" + System.DateTime.Now + "')>=0)"); int UserCountday = 0; UserCountday = B_Lebi_User.Counts("User_id_parent=" + user.id + " and (datediff(d,Time_Reg,'" + System.DateTime.Now.Date.ToString("yyyy-MM-dd") + "')<=0 and datediff(d,Time_Reg,'" + System.DateTime.Now + "')>=0)"); decimal Commission1 = 0; decimal Commission2 = 0; decimal Commission3 = 0; decimal.TryParse(bc.Angent1_Commission, out Commission1); decimal.TryParse(bc.Angent2_Commission, out Commission2); decimal.TryParse(bc.Angent3_Commission, out Commission3); if (user.DT_id == 0) { Lebi_Agent_UserLevel agent_userlevel = B_Lebi_Agent_UserLevel.GetModel("UserLevel_id = " + user.UserLevel_id + ""); if (agent_userlevel != null) { if (agent_userlevel.Angent1_Commission != -1) { Commission1 = agent_userlevel.Angent1_Commission; } if (agent_userlevel.Angent2_Commission != -1) { Commission2 = agent_userlevel.Angent2_Commission; } if (agent_userlevel.Angent3_Commission != -3) { Commission3 = agent_userlevel.Angent3_Commission; } } Lebi_Agent_User agent_user = B_Lebi_Agent_User.GetModel("User_id = " + user.id + ""); if (agent_user != null) { if (agent_user.Angent1_Commission != -1) { Commission1 = agent_user.Angent1_Commission; } if (agent_user.Angent2_Commission != -1) { Commission2 = agent_user.Angent2_Commission; } if (agent_user.Angent3_Commission != -1) { Commission3 = agent_user.Angent3_Commission; } } } else { Lebi_DT_Agent dt_agent = B_Lebi_DT_Agent.GetModel("DT_id = " + user.DT_id + ""); if (dt_agent != null) { if (dt_agent.IsUsedAgent == 1) { Commission1 = dt_agent.Angent1_Commission; Commission2 = dt_agent.Angent2_Commission; Commission3 = dt_agent.Angent3_Commission; } } } m.Money = Money; m.UserCount = UserCount; m.UserCountmonth = UserCountmonth; m.UserCountday = UserCountday; m.Commission1 = Commission1; m.Commission2 = Commission2; m.Commission3 = Commission3; Lebi_UserLevel userlevel = B_Lebi_UserLevel.GetModel(user.UserLevel_id); if (userlevel != null) { if (userlevel.IsUsedAgent == 0) //关闭注册 { m.Commission1 = 0; m.Commission2 = 0; m.Commission3 = 0; } } return(m); }
/// <summary> /// 推广佣金 /// </summary> private void AgentMoney() { //SystemLog.Add("计算佣金orderid" + Order.id + "userid" + OrderUser.User_id_parent); SystemLog.Add("推广佣金-开始"); if (OrderUser.User_id_parent == 0) { return; } //string Money_Product_Profit_ = Common.GetValue("select sum((Price - Price_Cost)*(Count-Count_Return)) from Lebi_Order_Product where Order_id = " + Order.id + ""); string Money_Product_Profit_ = Common.GetValue("select sum((Price - Price_Cost)*Count) from Lebi_Order_Product where Order_id = " + Order.id + ""); decimal Money_Product_Profit = 0; decimal.TryParse(Money_Product_Profit_, out Money_Product_Profit); if (Order.Type_id_OrderType == 212) { Money_Product_Profit = 0 - Money_Product_Profit;//zhangshijia 退货时产生负数佣金 } //处理一级代理 Lebi_User user1 = B_Lebi_User.GetModel(OrderUser.User_id_parent); if (user1 == null) { return; } decimal yongjin1 = 0; //1级佣金比例 decimal yongjin2 = 0; //2级佣金比例 decimal yongjin3 = 0; //3级佣金比例 Lebi_DT_Agent dt_agent = B_Lebi_DT_Agent.GetModel(0); Lebi_User DT_User = new Lebi_User(); Lebi_DT dt = new Lebi_DT(); int CommissionLevel = 3; if (Order.Supplier_id > 0) { Lebi_Supplier supplier = B_Lebi_Supplier.GetModel(Order.Supplier_id); if (supplier.IsSpread == 0) //商家未开启 { SystemLog.Add("推广佣金-商家未开启"); return; } } if (Order.DT_id > 0) { Money_Product_Profit = Order.DT_Money; //如果是分销商,利润为分销商佣金 dt_agent = B_Lebi_DT_Agent.GetModel("DT_id=" + Order.DT_id + ""); dt = B_Lebi_DT.GetModel(Order.DT_id); if (dt != null) { CommissionLevel = dt.CommissionLevel; } DT_User = B_Lebi_User.GetModel(dt.User_id); if (dt_agent.IsUsedAgent == 0) //分销商未开启 { SystemLog.Add("推广佣金-分销商未开启"); return; } // Money_Product_Profit = Order.DT_Money; ///zhangshijia注释,未找到DT_Money来源 //List<Lebi_Order_Product> order_pro = B_Lebi_Order_Product.GetModel(" Order_id = " + Order.id + ""); //foreach (Lebi_Order_Product op in order_pro) //{ //} } yongjin1 = GetAngentCommission1(dt_agent, user1); decimal money = Money_Product_Profit * yongjin1 / 100; if (Order.DT_id > 0) { if (DT_User.Money < money) { SystemLog.Add("推广佣金-分销商[" + DT_User.NickName + "-" + DT_User.id + "]金额不足,一级佣金生成失败"); return; } } AddMoney(money, user1, 391, 0, 0, 0); //SystemLog.Add("计算佣金" + user1.UserName + money.ToString()); if (Order.DT_id > 0) { AddMoney(0 - money, DT_User, 391, 0, 0, 0); } //处理2级代理 Lebi_User user2 = B_Lebi_User.GetModel(user1.User_id_parent); if (user2 == null) { user2 = new Lebi_User(); } else { if (CommissionLevel >= 2) { yongjin2 = GetAngentCommission2(dt_agent, user2); money = Money_Product_Profit * yongjin2 / 100; if (Order.DT_id > 0) { if (DT_User.Money < money) { SystemLog.Add("推广佣金-分销商金额不足,二级佣金生成失败"); return; } } AddMoney(money, user2, 391, 0, 0, 0); if (Order.DT_id > 0) { AddMoney(0 - money, DT_User, 391, 0, 0, 0); } } } //处理3级代理 if (CommissionLevel == 2) { return; } Lebi_User user3 = B_Lebi_User.GetModel(user2.User_id_parent); if (user3 != null) { yongjin3 = GetAngentCommission3(dt_agent, user3); money = Money_Product_Profit * yongjin3 / 100; if (Order.DT_id > 0) { if (DT_User.Money < money) { SystemLog.Add("推广佣金-分销商金额不足,三级佣金生成失败"); return; } } AddMoney(money, user3, 391, 0, 0, 0); if (Order.DT_id > 0) { AddMoney(0 - money, DT_User, 391, 0, 0, 0); } } ////处理条件佣金,佣金历史达到X时,可获得下线,下下线Y%的佣金 //decimal Angent_Commission_require = 0; //decimal.TryParse(bc.Angent_Commission_require, out Angent_Commission_require); //decimal yongjin3 = 0;//条件佣金比例 //decimal.TryParse(bc.Angent_Commission, out yongjin3); //money = Money_Product_Profit * yongjin3 / 100; //if (user1.AgentMoney_history > Angent_Commission_require) // AddMoney(money, user1, 395, 0, 0, 0); //if (user2.AgentMoney_history > Angent_Commission_require) // AddMoney(money, user2, 395, 0, 0, 0); }