OrderService.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. <?php
  2. namespace app\data\service;
  3. use think\admin\Service;
  4. /**
  5. * 商城订单数据服务
  6. * Class OrderService
  7. * @package app\data\service
  8. */
  9. class OrderService extends Service
  10. {
  11. /**
  12. * 获取随机减免金额
  13. * @return float
  14. */
  15. public function getReduct(): float
  16. {
  17. return rand(1, 100) / 100;
  18. }
  19. /**
  20. * 同步订单关联商品的库存
  21. * @param string $orderNo 订单编号
  22. * @return boolean
  23. * @throws \think\db\exception\DataNotFoundException
  24. * @throws \think\db\exception\DbException
  25. * @throws \think\db\exception\ModelNotFoundException
  26. */
  27. public function stock(string $orderNo): bool
  28. {
  29. $map = ['order_no' => $orderNo];
  30. $codes = $this->app->db->name('ShopOrderItem')->where($map)->column('goods_code');
  31. foreach (array_unique($codes) as $code) GoodsService::instance()->stock($code);
  32. return true;
  33. }
  34. /**
  35. * 根据订单更新用户等级
  36. * @param string $orderNo
  37. * @return array|null [USER, ORDER, ENTRY]
  38. * @throws \think\db\exception\DataNotFoundException
  39. * @throws \think\db\exception\DbException
  40. * @throws \think\db\exception\ModelNotFoundException
  41. */
  42. public function upgrade(string $orderNo): ?array
  43. {
  44. // 目标订单数据
  45. $map = [['order_no', '=', $orderNo], ['status', '>=', 4]];
  46. $order = $this->app->db->name('ShopOrder')->where($map)->find();
  47. if (empty($order)) return null;
  48. // 订单用户数据
  49. $user = $this->app->db->name('DataUser')->where(['id' => $order['uid']])->find();
  50. if (empty($user)) return null;
  51. // 更新用户购买资格
  52. $entry = $this->vipEntry($order['uid']);
  53. // 尝试绑定代理用户
  54. if (empty($user['pids']) && ($order['puid1'] > 0 || $user['pid1'] > 0)) {
  55. $puid1 = $order['puid1'] > 0 ? $order['puid1'] : $user['pid0'];
  56. UserUpgradeService::instance()->bindAgent($user['id'], $puid1);
  57. }
  58. // 重置用户信息并绑定订单
  59. $user = $this->app->db->name('DataUser')->where(['id' => $order['uid']])->find();
  60. if ($user['pid1'] > 0) {
  61. $this->app->db->name('ShopOrder')->where(['order_no' => $orderNo])->update([
  62. 'puid1' => $user['pid1'], 'puid2' => $user['pid2'],
  63. ]);
  64. }
  65. // 重新计算用户等级
  66. UserUpgradeService::instance()->upgrade($user['id'], true, $orderNo);
  67. return [$user, $order, $entry];
  68. }
  69. /**
  70. * 刷新用户入会礼包
  71. * @param integer $uid
  72. * @return integer
  73. * @throws \think\db\exception\DbException
  74. */
  75. private function vipEntry(int $uid): int
  76. {
  77. // 检查是否购买入会礼包
  78. $query = $this->app->db->table('shop_order a')->join('shop_order_item b', 'a.order_no=b.order_no');
  79. $count = $query->where("a.uid={$uid} and a.status>=4 and a.payment_status=1 and b.vip_entry>0")->count();
  80. $buyVipEntry = $count > 0 ? 1 : 0;
  81. // 用户最后支付时间
  82. $query = $this->app->db->name('ShopOrder');
  83. $buyLastMap = [['uid', '=', $uid], ['status', '>=', 4], ['payment_status', '=', 1]];
  84. $buyLastDate = $query->where($buyLastMap)->order('payment_datetime desc')->value('payment_datetime');
  85. // 更新用户支付信息
  86. $this->app->db->name('DataUser')->where(['id' => $uid])->update([
  87. 'buy_vip_entry' => $buyVipEntry, 'buy_last_date' => $buyLastDate,
  88. ]);
  89. return $buyVipEntry;
  90. }
  91. /**
  92. * 获取级别折扣比例
  93. * @param int $disId 折扣方案ID
  94. * @param int $vipCode 等级序号
  95. * @param float $disRate 默认比例
  96. * @return array [方案编号, 折扣比例]
  97. */
  98. public function discount(int $disId, int $vipCode, float $disRate = 100.00): array
  99. {
  100. if ($disId > 0) {
  101. $map = ['id' => $disId, 'status' => 1, 'deleted' => 0];
  102. $discount = $this->app->db->name('DataBaseDiscount')->where($map)->value('items');
  103. $disitems = json_decode($discount ?: '[]', true) ?: [];
  104. if (is_array($disitems) && count($disitems) > 0) foreach ($disitems as $vo) {
  105. if ($vo['level'] == $vipCode) $disRate = floatval($vo['discount']);
  106. }
  107. }
  108. return [$disId, $disRate];
  109. }
  110. /**
  111. * 绑定订单详情数据
  112. * @param array $data
  113. * @param boolean $fromer
  114. * @return array
  115. * @throws \think\db\exception\DataNotFoundException
  116. * @throws \think\db\exception\DbException
  117. * @throws \think\db\exception\ModelNotFoundException
  118. */
  119. public function buildData(array &$data = [], $fromer = true): array
  120. {
  121. // 关联发货信息
  122. $nobs = array_unique(array_column($data, 'order_no'));
  123. $trucks = $this->app->db->name('ShopOrderSend')->whereIn('order_no', $nobs)->column('*', 'order_no');
  124. foreach ($trucks as &$item) unset($item['id'], $item['uid'], $item['status'], $item['deleted'], $item['create_at']);
  125. // 关联订单商品
  126. $query = $this->app->db->name('ShopOrderItem')->where(['status' => 1, 'deleted' => 0]);
  127. $items = $query->withoutField('id,uid,status,deleted,create_at')->whereIn('order_no', $nobs)->select()->toArray();
  128. // 关联用户数据
  129. $fields = 'phone,username,nickname,headimg,status,vip_code,vip_name';
  130. UserAdminService::instance()->buildByUid($data, 'uid', 'user', $fields);
  131. if ($fromer) UserAdminService::instance()->buildByUid($data, 'puid1', 'fromer', $fields);
  132. foreach ($data as &$vo) {
  133. [$vo['sales'], $vo['truck'], $vo['items']] = [0, $trucks[$vo['order_no']] ?? [], []];
  134. foreach ($items as $item) if ($vo['order_no'] === $item['order_no']) {
  135. $vo['sales'] += $item['stock_sales'];
  136. $vo['items'][] = $item;
  137. }
  138. }
  139. return $data;
  140. }
  141. }