Order.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. <?php
  2. namespace app\api\model\dealer;
  3. use app\common\model\dealer\Order as OrderModel;
  4. use app\common\service\Order as OrderService;
  5. use app\common\enum\OrderType as OrderTypeEnum;
  6. /**
  7. * 分销商订单模型
  8. * Class Apply
  9. * @package app\api\model\dealer
  10. */
  11. class Order extends OrderModel
  12. {
  13. /**
  14. * 隐藏字段
  15. * @var array
  16. */
  17. protected $hidden = [
  18. 'update_time',
  19. ];
  20. /**
  21. * 获取分销商订单列表
  22. * @param $user_id
  23. * @param int $is_settled
  24. * @return \think\Paginator
  25. * @throws \think\exception\DbException
  26. */
  27. public function getList($user_id, $is_settled = -1)
  28. {
  29. $is_settled > -1 && $this->where('is_settled', '=', !!$is_settled);
  30. $data = $this->with(['user'])
  31. ->where('first_user_id|second_user_id|third_user_id', '=', $user_id)
  32. ->order(['create_time' => 'desc'])
  33. ->paginate(15, false, [
  34. 'query' => \request()->request()
  35. ]);
  36. if ($data->isEmpty()) {
  37. return $data;
  38. }
  39. // 整理订单信息
  40. $with = ['goods' => ['image', 'refund'], 'address', 'user'];
  41. return OrderService::getOrderList($data, 'order_master', $with);
  42. }
  43. /**
  44. * 创建分销商订单记录
  45. * @param $order
  46. * @param int $order_type 订单类型 (10商城订单 20拼团订单)
  47. * @return bool|false|int
  48. * @throws \think\exception\DbException
  49. */
  50. public static function createOrder(&$order, $order_type = OrderTypeEnum::MASTER)
  51. {
  52. // 分销订单模型
  53. $model = new self;
  54. // 分销商基本设置
  55. $setting = Setting::getItem('basic');
  56. // 是否开启分销功能
  57. if (!$setting['is_open']) {
  58. return false;
  59. }
  60. // 获取当前买家的所有上级分销商用户id
  61. $dealerUser = $model->getDealerUserId($order['user_id'], $setting['level'], $setting['self_buy']);
  62. // 非分销订单
  63. if (!$dealerUser['first_user_id']) {
  64. return false;
  65. }
  66. // 计算订单分销佣金
  67. $capital = $model->getCapitalByOrder($order);
  68. // 保存分销订单记录
  69. return $model->save([
  70. 'user_id' => $order['user_id'],
  71. 'order_id' => $order['order_id'],
  72. 'order_type' => $order_type,
  73. // 'order_no' => $order['order_no'], // 废弃
  74. 'order_price' => $capital['orderPrice'],
  75. 'first_money' => max($capital['first_money'], 0),
  76. 'second_money' => max($capital['second_money'], 0),
  77. 'third_money' => max($capital['third_money'], 0),
  78. 'first_user_id' => $dealerUser['first_user_id'],
  79. 'second_user_id' => $dealerUser['second_user_id'],
  80. 'third_user_id' => $dealerUser['third_user_id'],
  81. 'is_settled' => 0,
  82. 'wxapp_id' => $model::$wxapp_id
  83. ]);
  84. }
  85. /**
  86. * 获取当前买家的所有上级分销商用户id
  87. * @param $user_id
  88. * @param $level
  89. * @param $self_buy
  90. * @return mixed
  91. * @throws \think\exception\DbException
  92. */
  93. private function getDealerUserId($user_id, $level, $self_buy)
  94. {
  95. $dealerUser = [
  96. 'first_user_id' => $level >= 1 ? Referee::getRefereeUserId($user_id, 1, true) : 0,
  97. 'second_user_id' => $level >= 2 ? Referee::getRefereeUserId($user_id, 2, true) : 0,
  98. 'third_user_id' => $level == 3 ? Referee::getRefereeUserId($user_id, 3, true) : 0
  99. ];
  100. // 分销商自购
  101. if ($self_buy && User::isDealerUser($user_id)) {
  102. return [
  103. 'first_user_id' => $user_id,
  104. 'second_user_id' => $dealerUser['first_user_id'],
  105. 'third_user_id' => $dealerUser['second_user_id'],
  106. ];
  107. }
  108. return $dealerUser;
  109. }
  110. }