Utils.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using Library;
  5. using MySystem.PxcModels;
  6. namespace MySystem
  7. {
  8. public class Utils
  9. {
  10. public readonly static Utils Instance = new Utils();
  11. private Utils()
  12. { }
  13. /// <summary>
  14. /// 操作收支明细
  15. /// </summary>
  16. /// <param name="UserId"></param>
  17. /// <param name="Money"></param>
  18. /// <param name="ChangeType"></param>
  19. public void OpAccount(int UserId, decimal Money, int ChangeType, bool IsTotal = true)
  20. {
  21. WebCMSEntities db = new WebCMSEntities();
  22. UserAccount account = db.UserAccount.FirstOrDefault(m => m.Id == UserId);
  23. if (account == null)
  24. {
  25. account = db.UserAccount.Add(new UserAccount()
  26. {
  27. Id = UserId,
  28. UserId = UserId,
  29. }).Entity;
  30. db.SaveChanges();
  31. }
  32. decimal BeforeTotalAmount = account.TotalAmount; //变更前总金额
  33. decimal BeforeFreezeAmount = account.FreezeAmount; //变更前冻结金额
  34. decimal BeforeBalanceAmount = account.BalanceAmount; //变更前余额
  35. account.BalanceAmount += Money;
  36. if(IsTotal)
  37. {
  38. account.TotalAmount += Money;
  39. }
  40. decimal AfterTotalAmount = account.TotalAmount; //变更后总金额
  41. decimal AfterFreezeAmount = account.FreezeAmount; //变更后冻结金额
  42. decimal AfterBalanceAmount = account.BalanceAmount; //变更后余额
  43. UserAccountRecord userAccountRecord = db.UserAccountRecord.Add(new UserAccountRecord()
  44. {
  45. CreateDate = DateTime.Now,
  46. UpdateDate = DateTime.Now,
  47. UserId = UserId, //创客
  48. ChangeType = ChangeType, //变动类型
  49. ChangeAmount = Money, //变更金额
  50. BeforeTotalAmount = BeforeTotalAmount, //变更前总金额
  51. AfterTotalAmount = AfterTotalAmount, //变更后总金额
  52. BeforeFreezeAmount = BeforeFreezeAmount, //变更前冻结金额
  53. AfterFreezeAmount = AfterFreezeAmount, //变更后冻结金额
  54. BeforeBalanceAmount = BeforeBalanceAmount, //变更前余额
  55. AfterBalanceAmount = AfterBalanceAmount, //变更后余额
  56. }).Entity;
  57. db.SaveChanges();
  58. db.Dispose();
  59. }
  60. public void ToChargeAmount(int UserId, decimal Money)
  61. {
  62. WebCMSEntities db = new WebCMSEntities();
  63. UserAccount account = db.UserAccount.FirstOrDefault(m => m.Id == UserId);
  64. if (account == null)
  65. {
  66. account = db.UserAccount.Add(new UserAccount()
  67. {
  68. Id = UserId,
  69. UserId = UserId,
  70. }).Entity;
  71. db.SaveChanges();
  72. }
  73. account.ToChargeAmount += Money;
  74. db.SaveChanges();
  75. db.Dispose();
  76. }
  77. /// <summary>
  78. /// 判断是否达标创客
  79. /// </summary>
  80. /// <param name="UserId"></param>
  81. /// <returns></returns>
  82. public bool IsStandardUser(int UserId)
  83. {
  84. WebCMSEntities db = new WebCMSEntities();
  85. // Users user = db.Users.FirstOrDefault(m => m.Id == UserId) ?? new Users();
  86. UserRankItem user = PosCouponPrizeService.Instance.GetUserLevel(UserId);
  87. if(user.UserType == 1)
  88. {
  89. return true;
  90. }
  91. if(user.LeaderLevel > 0)
  92. {
  93. Leaders leader = db.Leaders.FirstOrDefault(m => m.Id == UserId) ?? new Leaders();
  94. if(leader.ExpiredDate > DateTime.Now)
  95. {
  96. return true;
  97. }
  98. }
  99. MpMainModels.WebCMSEntities mpdb = new MpMainModels.WebCMSEntities();
  100. MpMainModels2.WebCMSEntities mpdb2 = new MpMainModels2.WebCMSEntities();
  101. int couponCount = db.PosCoupons.Count(m => m.UserId == UserId && m.IsUse == 0); //1. 个人名下电签兑换券 + 大机兑换券 ≥ 3
  102. // TODO:待确认条件
  103. if(couponCount >= 3)
  104. {
  105. db.Dispose();
  106. mpdb.Dispose();
  107. mpdb2.Dispose();
  108. return true;
  109. }
  110. else
  111. {
  112. List<int> ids = new List<int>();
  113. ids.Add(10);
  114. ids.Add(11);
  115. ids.Add(77);
  116. ids.Add(78);
  117. ids.Add(79);
  118. bool orderCheck = db.Orders.Any(m => m.UserId == UserId && ids.Contains(m.ProductId)); //1. 商城下单过id为10、11、77、78、79的商品
  119. if(orderCheck)
  120. {
  121. db.Dispose();
  122. mpdb.Dispose();
  123. mpdb2.Dispose();
  124. return true;
  125. }
  126. else
  127. {
  128. //1. 激活POS机数量 + 激活来客吧商户数量 + 激活广电卡数量 ≥ 3
  129. int ActiveCount = db.PosMachinesTwo.Count(m => m.BuyUserId == UserId && m.ActivationState == 1);
  130. int ActMerchantCount = mpdb.MerchantDepositOrder.Count(m => m.UserId == UserId && m.Status > 0) + mpdb2.MerchantDepositOrder.Count(m => m.UserId == UserId && m.Status > 0);
  131. if(ActiveCount + ActMerchantCount >= 3)
  132. {
  133. db.Dispose();
  134. mpdb.Dispose();
  135. mpdb2.Dispose();
  136. return true;
  137. }
  138. }
  139. }
  140. db.Dispose();
  141. mpdb.Dispose();
  142. mpdb2.Dispose();
  143. return false;
  144. }
  145. /// <summary>
  146. /// 预设职级
  147. /// </summary>
  148. /// <param name="UserId"></param>
  149. /// <param name="LeaderKind"></param>
  150. public void LeaderPreUserLevel(int UserId, int UserLevel, DateTime ExpiredDate)
  151. {
  152. WebCMSEntities db = new WebCMSEntities();
  153. UserRankWhite rank = db.UserRankWhite.FirstOrDefault(m => m.Id == UserId);
  154. if(rank == null)
  155. {
  156. rank = db.UserRankWhite.Add(new UserRankWhite()
  157. {
  158. CreateDate = DateTime.Now, //设置时间
  159. UserId = UserId, //用户
  160. Id = UserId,
  161. }).Entity;
  162. db.SaveChanges();
  163. }
  164. rank.Rank = UserLevel;
  165. rank.UpdateDate = ExpiredDate;
  166. db.SaveChanges();
  167. db.Dispose();
  168. }
  169. #region 获取创客职级
  170. public int GetUserLevel(int Id)
  171. {
  172. WebCMSEntities db = new WebCMSEntities();
  173. DateTime now = DateTime.Now;
  174. List<int> Levels = new List<int>();
  175. Users user = db.Users.FirstOrDefault(m => m.Id == Id) ?? new Users();
  176. UserRankWhite userRank = db.UserRankWhite.FirstOrDefault(m => m.Id == Id && m.UpdateDate > now) ?? new UserRankWhite();
  177. LeaderRankWhite leaderRank = db.LeaderRankWhite.FirstOrDefault(m => m.Id == Id && m.UpdateDate > now) ?? new LeaderRankWhite();
  178. OperatorRankWhite operatorRank = db.OperatorRankWhite.FirstOrDefault(m => m.Id == Id && m.UpdateDate > now) ?? new OperatorRankWhite();
  179. Levels.Add(user.UserLevel);
  180. Levels.Add(userRank.Rank);
  181. Levels.Add(leaderRank.Rank);
  182. Levels.Add(operatorRank.Rank);
  183. db.Dispose();
  184. return Levels.Max();
  185. }
  186. #endregion
  187. #region 解析机具押金值,单位转换
  188. public string TransferDeposit(PosMachinesTwo newpos, string Deposit)
  189. {
  190. decimal DepositNumber = decimal.Parse(function.CheckNum(Deposit));
  191. if(DepositNumber == 0)
  192. {
  193. return "";
  194. }
  195. WebCMSEntities db = new WebCMSEntities();
  196. int BrandId = newpos.BrandId;
  197. KqProducts pro = db.KqProducts.FirstOrDefault(m => m.Id == BrandId) ?? new KqProducts();
  198. if(pro.NoticeMoneyUnit == 1 && DepositNumber > 1000)
  199. {
  200. DepositNumber = DepositNumber / 100;
  201. }
  202. if(pro.NoticeMoneyUnit == 2 && DepositNumber < 1000)
  203. {
  204. DepositNumber = DepositNumber * 100;
  205. }
  206. db.Dispose();
  207. return DepositNumber.ToString("f2");
  208. }
  209. #endregion
  210. #region 运营中心额度变更
  211. public void OperateAmountChange(OpModels.WebCMSEntities db, OpAmountItem param)
  212. {
  213. if(param.UseAmount <= 0) return;
  214. function.WriteLog(Newtonsoft.Json.JsonConvert.SerializeObject(param), "运营中心额度变更测试");
  215. OpModels.UserAccount account = db.UserAccount.FirstOrDefault(m => m.Id == param.UserId);
  216. if (account == null)
  217. {
  218. account = db.UserAccount.Add(new OpModels.UserAccount()
  219. {
  220. Id = param.UserId,
  221. UserId = param.UserId,
  222. }).Entity;
  223. db.SaveChanges();
  224. }
  225. decimal BeforeAmount = account.ValidForGetAmount + account.TotalAmt + account.ValidAmount;
  226. if(param.NoAccount == 0)
  227. {
  228. if(param.OperateType == 0 && param.UseTotalAmt > 0 && param.UseValidForGetAmount > 0 && param.UseValidAmount == 0)
  229. {
  230. account.TotalAmt -= param.UseTotalAmt;
  231. account.ValidForGetAmount += param.UseValidForGetAmount;
  232. }
  233. else
  234. {
  235. if(param.OperateType == 1)
  236. {
  237. account.TotalAmt += param.UseTotalAmt;
  238. account.ValidForGetAmount += param.UseValidForGetAmount;
  239. account.ValidAmount += param.UseValidAmount;
  240. }
  241. else if(param.OperateType == 2)
  242. {
  243. account.TotalAmt -= param.UseTotalAmt;
  244. account.ValidForGetAmount -= param.UseValidForGetAmount;
  245. account.ValidAmount -= param.UseValidAmount;
  246. }
  247. }
  248. }
  249. function.WriteLog("1", "运营中心额度变更测试");
  250. decimal AfterAmount = account.ValidForGetAmount + account.TotalAmt + account.ValidAmount;
  251. OpModels.AmountRecordNew add = db.AmountRecordNew.Add(new OpModels.AmountRecordNew()
  252. {
  253. CreateDate = DateTime.Now,
  254. UpdateDate = DateTime.Now,
  255. ChangeTypeId = param.ChangeType,
  256. Remark = param.Remark,
  257. AfterValidForGetAmount = account.ValidForGetAmount,
  258. AfterTotalAmt = account.TotalAmt,
  259. AfterValidAmount = account.ValidAmount,
  260. OperateType = param.OperateType,
  261. AfterAmount = AfterAmount,
  262. BeforeAmount = BeforeAmount,
  263. UseAmount = param.UseAmount,
  264. UserId = param.UserId,
  265. UseValidForGetAmount = param.UseValidForGetAmount,
  266. UseTotalAmt = param.UseTotalAmt,
  267. UseValidAmount = param.UseValidAmount,
  268. DataType = param.DataType,
  269. DataId = param.DataId,
  270. }).Entity;
  271. function.WriteLog("2", "运营中心额度变更测试");
  272. db.SaveChanges();
  273. function.WriteLog("3\n\n", "运营中心额度变更测试");
  274. }
  275. #endregion
  276. }
  277. }