StoreGp.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. <?php
  2. namespace app\models\store;
  3. use app\models\user\User;
  4. use app\models\user\UserBill;
  5. use crmeb\basic\BaseModel;
  6. use crmeb\traits\ModelTrait;
  7. use think\Exception;
  8. class StoreGp extends BaseModel
  9. {
  10. use ModelTrait;
  11. /**
  12. * 创建公排
  13. * @param $order
  14. */
  15. public static function createGp($order)
  16. {
  17. try {
  18. $no = intval(self::value('max(no)') ?: 0) + 1;
  19. list($p_no, $no_path,$gp_id) = self::getpath($no);
  20. $order_id = $order['id'];
  21. $add_time = time();
  22. $price = $order['total_price'];
  23. $uid = $order['uid'];
  24. self::create(compact('no', 'uid', 'order_id', 'add_time', 'price', 'p_no', 'no_path'));
  25. self::where('no', $p_no)->inc('cts', 1)->update();
  26. self::where('no', $gp_id)->inc('team_cts', 1)->update();
  27. $p_no_cts = self::where('no', $gp_id)->value('team_cts');
  28. if ($p_no_cts % 3 == 0) {
  29. $info = self::where('no', $gp_id)->find();
  30. $sp_userInfo = User::find($info['uid']);
  31. switch ($p_no_cts)
  32. {
  33. case 3:
  34. $sp_brokeragePrice = $order['out_amount']-3000;
  35. $balance = bcadd($sp_userInfo['brokerage_price'], $sp_brokeragePrice, 2);
  36. $mark = "公排号:" . $no . '满3个拥金' . $order['out_amount'] . "元,订单号:" . $order['order_id'];
  37. $res = UserBill::income('满3个拥金', $sp_userInfo['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  38. $sp_brokeragePrice1 = 3000;
  39. $gp_balance = bcadd($sp_userInfo['gp_now_money'], $sp_brokeragePrice1, 2);
  40. $mark = "公排号:" . $no . '满3个加报单余额' . $order['out_amount'] . "元,订单号:" . $order['order_id'];
  41. $res = UserBill::income('满3个报单余额', $sp_userInfo['uid'], 'now_money', 'brokerage', $sp_brokeragePrice1, $order['id'], $balance, $mark, 1);
  42. User::where('uid', $sp_userInfo['uid'])->inc('brokerage_price', $sp_brokeragePrice)->inc('gp_now_money',$sp_brokeragePrice1)->update();
  43. break;
  44. case 6:
  45. case 9:
  46. $sp_brokeragePrice = $order['out_amount'];
  47. $balance = bcadd($sp_userInfo['brokerage_price'], $sp_brokeragePrice, 2);
  48. $mark = "公排号:" . $no . '满'.$p_no_cts.'个拥金' . $order['out_amount'] . "元,订单号:" . $order['order_id'];
  49. $res = UserBill::income('满'.$p_no_cts.'个拥金', $sp_userInfo['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  50. User::where('uid', $sp_userInfo['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  51. break;
  52. case 12:
  53. $sp_brokeragePrice = $order['out_amount']-1000;
  54. $balance = bcadd($sp_userInfo['brokerage_price'], $sp_brokeragePrice, 2);
  55. $mark = "公排号:" . $no . '满'.$p_no_cts.'个拥金' . $order['out_amount'] . "元,订单号:" . $order['order_id'];
  56. $res = UserBill::income('满'.$p_no_cts.'个拥金', $sp_userInfo['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  57. User::where('uid', $sp_userInfo['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  58. self::where('no', $gp_id)->update(['status'=>1]);
  59. break;
  60. }
  61. }
  62. if ($p_no_cts % 12 == 0 && sizeof($no_path) > 1) {
  63. $path = array_reverse($no_path);
  64. $n = 0;
  65. foreach ($path as $v) {
  66. $n++;
  67. if ($n <= 1) continue;
  68. $sp_brokeragePrice = $order['team'];
  69. $user = user::find($v);
  70. $balance = bcadd($user['brokerage_price'], $sp_brokeragePrice, 2);
  71. $mark = "公排号:" . $no . '团队奖' . floatval($sp_brokeragePrice) . "元,订单号:" . $order['order_id'];
  72. $res1 = UserBill::income('团队奖', $user['uid'], 'now_money', 'brokerage', $sp_brokeragePrice, $order['id'], $balance, $mark, 1);
  73. User::where('uid', $user['uid'])->inc('brokerage_price', $sp_brokeragePrice)->update();
  74. }
  75. }
  76. return true;
  77. }catch (Exception $e)
  78. {
  79. return false;
  80. }
  81. }
  82. /**
  83. * 获取上级及路径
  84. * @param $no
  85. * @return array
  86. * @throws \think\db\exception\DataNotFoundException
  87. * @throws \think\db\exception\DbException
  88. * @throws \think\db\exception\ModelNotFoundException
  89. */
  90. private static function getpath($no)
  91. {
  92. $no_path = [];$p_no=0;
  93. if($no==1) {
  94. $no_path[] =1;
  95. $gp_id = 1;
  96. }
  97. else
  98. {
  99. $gp_id = self::where('team_cts','<',12)->value('no');
  100. $min = self::where('cts','<',12)->order("id asc")->find();
  101. $p_no = $min['no'];
  102. $no_path = explode(",",$min['no_path']);
  103. $no_path[] = $no;
  104. }
  105. return compact('p_no','no_path','gp_id');
  106. }
  107. }