Order.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344
  1. <?php
  2. namespace app\api\controller\v1;
  3. use app\BaseController;
  4. use app\model\api\ExpCost;
  5. use app\model\api\MemberDetail;
  6. use app\model\Api\MemberShop;
  7. use app\model\api\Order as OrderModel;
  8. use app\model\api\OrderInfo;
  9. use app\model\api\Product;
  10. use app\model\api\SiteProduct;
  11. use app\model\api\UserAddress;
  12. use app\model\api\Warehouse;
  13. use app\model\system\ProductAttr;
  14. use app\Request;
  15. use library\services\UtilService;
  16. use library\utils\Region;
  17. use think\db\exception\DbException;
  18. use think\facade\Db;
  19. class Order extends BaseController
  20. {
  21. /**
  22. * 获取产品信息
  23. */
  24. public function getProductInfo(Request $request){
  25. $where = UtilService::getMore([
  26. ['product_id', 0],
  27. ['unique', '']
  28. ], $request);
  29. $data = Db::name('ProductAttrValue')->where('product_id', $where['product_id'])->where('unique', $where['unique'])->find();
  30. if($data['price'] == '0.00'){
  31. $data['price'] = round($data['ot_price'] * 1.15, 2);
  32. }
  33. $data['store_name'] = Db::name('Product')->where('id', $where['product_id'])->value('store_name');
  34. return app('json')->success($data);
  35. }
  36. /**
  37. * 买样订单
  38. * @param Request $request
  39. */
  40. public function buyOrder(Request $request)
  41. {
  42. $data = UtilService::getMore([
  43. ['pro_id', '', 'empty', '参数错误'],
  44. ['unique', '', 'empty', '参数错误'],
  45. ['num', '', 'empty', '参数错误'],
  46. ['addressId', '', 'empty', '参数错误'],
  47. ['pro_price', 0],
  48. ['postage', 0],
  49. ['all_price', 0],
  50. ['mono', '']
  51. ], $request);
  52. try {
  53. OrderModel::beginTrans();
  54. $addressId = $data['addressId'];
  55. unset($data['addressId']);
  56. $data['order_id'] = 'TF' . time() . sprintf('%04d', rand(0, 1000)) . $request->user['uid']; //订单号
  57. $data['uid'] = $request->user['uid'];
  58. $data['time'] = time();
  59. $oId = OrderModel::insertGetId($data);
  60. $address = UserAddress::find($addressId);
  61. $save['o_id'] = $oId;
  62. $save['uid'] = $request->user['uid'];
  63. $save['name'] = $address['real_name'];
  64. $save['mobile'] = $address['phone'];
  65. $save['address'] = $address['province'] . $address['city'] . $address['district'] . $address['detail'];
  66. $save['money'] = $data['all_price'];
  67. $save['pro_price'] = $data['pro_price'];
  68. $save['pro_id'] = $data['pro_id'];
  69. $save['exp_price'] = $data['postage'];
  70. $save['time'] = time();
  71. OrderInfo::insert($save);
  72. OrderModel::commitTrans();
  73. } catch (DbException $db) {
  74. OrderModel::rollbackTrans();
  75. return app('json')->fail("下单失败,原因:" . $db->getMessage());
  76. }
  77. return app('json')->success([
  78. 'order_id' => $data['order_id'],
  79. 'price' => $data['all_price']
  80. ]);
  81. }
  82. /**
  83. * 代发订单
  84. * @param Request $request
  85. */
  86. public function subOrder(Request $request)
  87. {
  88. [$orderAr, $proId, $warehouseId, $expId, $platformId, $mono, $extraFreight] = UtilService::getMore([
  89. ['orderAr', '', 'empty', '参数错误'],
  90. ['proId', '', 'empty', '参数错误'],
  91. ['warehouseId', '', 'empty', '参数错误'],
  92. ['expId', '', 'empty', '请选择运送方式'],
  93. ['platformId', '', 'empty', '参数错误'],
  94. ['mono', ''],
  95. ['extraFreight', 0]
  96. ], $request, true);
  97. $expPrice = 0; //邮费费用
  98. $expressId = 0; //快递ID
  99. $siteExpCommission = 0;//分站佣金费用
  100. //检测数据
  101. $sitePro = (new SiteProduct)->getItem($proId);
  102. if ($sitePro['count'] <= 0 || count($orderAr) > $sitePro['count']) {
  103. return app('json')->fail("订单产品数量不足,请重新选择!");
  104. }
  105. //判断仓库是否可以下单
  106. $warehouseIds = explode(',',$sitePro['warehouse_ids']);
  107. if(!in_array($warehouseId,$warehouseIds)) {
  108. return app('json')->fail("请重新选择产品!");
  109. }
  110. $warehouse = (new Warehouse)->where('id',$warehouseId)->find();
  111. if(empty($warehouse) || empty($warehouse['status'])) {
  112. return app('json')->fail("分仓已下架,请选择其他分仓");
  113. }
  114. $region = new Region;
  115. //检查地址数据
  116. foreach ($orderAr as $k => $v) {
  117. $rData = $region->getRegion($v['address']);
  118. if (empty($rData['province']) ||
  119. empty($rData['city']) ||
  120. empty($rData['area'])
  121. ) {
  122. // return app('json')->fail('第' . (intval($k) + 1) .'行,'.$v['address'] .'地址信息有误,请重新检查省市区!');
  123. }
  124. }
  125. //订单总数
  126. $orderCount = count($orderAr);
  127. $price = $sitePro['price'] * $orderCount;
  128. $siteProCommission = $sitePro['price'] > $sitePro['commission'] ? ($sitePro['price'] - $sitePro['commission']) : 0;//分站佣金
  129. //快递信息
  130. $expCode = new ExpCost;
  131. $expCode->getExpCostData($request->site['sassid'], $request->user['levelid']);
  132. $expData = array_filter($expCode->getWareHouseExpCost($warehouseId, '*'), function ($item) use ($expId) {
  133. if ($item['id'] == $expId) {
  134. return true;
  135. }
  136. });
  137. //如果有快递信息,分析分账提成 || 用户推荐佣金
  138. if (!empty($expData)) {
  139. $expressId = $expData[0]['express_id'];
  140. $expPrice = $expData[0]['money'];
  141. //分站金额
  142. $money = $expCode->getSysExpCostPrice($expressId, $warehouseId, $request->site['sassid']);
  143. $siteExpCommission = empty($money) ? 0 : ($expPrice > $money ? ($expPrice - $money) : 0);
  144. }
  145. if (empty($expressId)) {
  146. return app('json')->fail("本次邮寄方式不存在,请重新选择邮寄方式。");
  147. }
  148. //获取低价
  149. $floorExp = $expCode
  150. ->where('warehouse_id', $warehouseId)
  151. ->where('express_id', $expressId)
  152. ->where('sassid', 0)
  153. ->where('level_id', -1)
  154. ->value('money');
  155. //会员店铺
  156. $shopAr = [];
  157. foreach ($orderAr as $v) {
  158. $shop_name = trim($v['shop_name']);
  159. if (!empty($shop_name)) {
  160. $shopAr[$shop_name] = ['name' => $shop_name];
  161. }
  162. }
  163. try {
  164. \app\model\api\Order::beginTrans();
  165. $mShop = new MemberShop;
  166. foreach ($shopAr as $k => $v) {
  167. $shopId = $mShop->where('name', $k)
  168. ->where('uid', $this->user['uid'])
  169. ->value('id');
  170. if (empty($shopId)) $shopId = $mShop->insertGetId(['name' => $k, 'uid' => $this->user['uid']]);
  171. $shopAr[$k]['id'] = $shopId;
  172. }
  173. //下单
  174. $save['order_id'] = 'TF' . time() . sprintf('%04d', rand(0, 1000)) . $request->user['uid'];//订单号
  175. $save['all_price'] = $price + $expPrice * $orderCount + $extraFreight;//总金额 [价格 + 快递*产品数量]
  176. $save['pro_site_commission'] = $siteProCommission * $orderCount;//产品分站佣金
  177. $save['exp_site_commission'] = $siteExpCommission * $orderCount;//快递分站佣金
  178. $save['site_commission'] = $save['pro_site_commission'] + $save['exp_site_commission'];//分站提成
  179. $save['pro_id'] = $sitePro['id'];//产品ID
  180. $save['platform_id'] = $platformId;//来源[拼多多,淘宝]
  181. $save['warehouse_id'] = $warehouseId;//仓库来源
  182. $save['status'] = 0;//状态
  183. $save['time'] = time();
  184. $save['express_id'] = $expressId;//快递类型
  185. $save['sassid'] = $request->site['sassid'];//分站
  186. $save['mono'] = $mono;//备注
  187. $save['pro_price'] = $price;//产品价格
  188. $save['uid'] = $request->user['uid'];
  189. $oId = (new Order)->insertGetId($save);
  190. foreach ($orderAr as $k => $v) {
  191. $shop_name = trim($v['shop_name']);
  192. $d = [];
  193. $d['o_id'] = $oId;
  194. $d['in_order_id'] = $save['order_id'] . '-' . ($k + 1);
  195. $d['out_order_id'] = $v['out_order_id'];
  196. $d['name'] = $v['name'];
  197. $d['mobile'] = $v['mobile'];
  198. $d['address'] = $v['address'];
  199. $d['pro_price'] = $sitePro['price'];
  200. $d['pro_id'] = $sitePro['id'];
  201. $d['exp_id'] = $expressId;
  202. if(strstr($d['address'], '北京')){
  203. $d['exp_price'] = $expPrice + $warehouse['beijing'];
  204. }else if(strstr($d['address'], '上海')){
  205. $d['exp_price'] = $expPrice + $warehouse['shanghai'];
  206. }else if(strstr($d['address'], '青海')){
  207. $d['exp_price'] = $expPrice + $warehouse['qinghai'];
  208. }else{
  209. $d['exp_price'] = $expPrice;
  210. }
  211. $d['money'] = $sitePro['price'] + $d['exp_price'];
  212. $d['sassid'] = $request->site['sassid'];
  213. $d['uid'] = $request->user['uid'];
  214. $d['time'] = time();
  215. $d['platform_id'] = $platformId;
  216. $d['warehouse_id'] = $warehouseId;
  217. $d['pro_site_commission'] = $siteProCommission;
  218. $d['exp_site_commission'] = $siteExpCommission;
  219. $d['site_commission'] = $siteProCommission + $siteExpCommission;
  220. $d['exp_floor_price'] = empty($floorExp) ? 0 : $floorExp;
  221. $d['shop_id'] = empty($shop_name) ? 0 : $shopAr[$shop_name]['id'];
  222. (new OrderInfo)->insert($d);
  223. }
  224. Order::commitTrans();
  225. } catch (DbException $db) {
  226. Order::rollbackTrans();
  227. return app('json')->fail("下单失败,理由:" . $db->getMessage());
  228. }
  229. return app('json')->success([
  230. 'order_id' => $save['order_id'],
  231. 'price' => $save['all_price'],
  232. ]);
  233. }
  234. /**
  235. * 余额支付
  236. * @param Request $request
  237. */
  238. public function balancePay(Request $request)
  239. {
  240. [$orderId] = UtilService::getMore([
  241. ['order_id', '', 'empty', '参数错误'],
  242. ], $request, true);
  243. $order = OrderModel::where('order_id', $orderId)->find();
  244. if (empty($order)) {
  245. return app('json')->fail('找不到订单信息');
  246. }
  247. //订单已付款
  248. if (!empty($order['is_pay'])) {
  249. return app('json')->fail('订单已经支付成功');
  250. }
  251. if ($order['all_price'] > $request->user['money']) {
  252. return app('json')->fail('余额不足!');
  253. }
  254. $res = (new MemberDetail)->consumption($order['all_price'], $request->user['uid'], [
  255. 'mobile' => $request->user['mobile'],
  256. 'order_id' => $orderId,
  257. 'money' => $order['all_price']
  258. ]);
  259. if ($res) {
  260. //减库存加销量
  261. (new Product)->where('id', $order['pro_id'])->dec('stock', $order['num'])->inc('sales', $order['num'])->update();
  262. Db::name('ProductAttrValue')->where('product_id', $order['pro_id'])->where('unique', $order['unique'])->dec('stock', $order['num'])->inc('sales', $order['num'])->update();
  263. //改订单状态
  264. OrderModel::where('order_id', $orderId)->save([
  265. 'status' => 1,
  266. 'is_pay' => 1,
  267. 'pay_type' => 'yue',
  268. 'pay_time' => time()
  269. ]);
  270. //改子订单状态
  271. OrderInfo::where('o_id', $order['id'])->save(['status' => 1,]);
  272. //设置维护人
  273. /*$last_con_time = (new Member)->where('uid', $request->user['uid'])->value('last_con_time');
  274. if($last_con_time == 0){
  275. $follow = (new MemberFollow)->where('uid', $request->user['uid'])->where('admin_id', 99)->find();
  276. if($follow){
  277. (new Member)->where('uid', $request->user['uid'])->save(['admin_id' => 99]);
  278. }else{
  279. (new Member)->where('uid', $request->user['uid'])->save(['admin_id' => 100]);
  280. }
  281. }
  282. (new Member)->where('uid', $request->user['uid'])->save(['last_con_time' => time()]);*/
  283. return app('json')->success(['msg' => '支付成功']);
  284. } else {
  285. return app('json')->fail('支付失败');
  286. }
  287. }
  288. /**
  289. * 获取订单列表
  290. * @param Request $request
  291. */
  292. public function getOrderList(Request $request)
  293. {
  294. $where = UtilService::getMore([
  295. ['type', ''],
  296. ['page', 0],
  297. ['limit', '']
  298. ], $request);
  299. $data = (new OrderModel)->getUserOrderList($request->user['uid'], $where);
  300. return app('json')->success($data);
  301. }
  302. /**
  303. * 取消订单
  304. * @param Request $request
  305. */
  306. public function cancelOrder(Request $request)
  307. {
  308. $post = UtilService::getMore([
  309. ['id', '', 'empty', '参数错误'],
  310. ], $request);
  311. $order = new OrderModel;
  312. $data = $order
  313. ->where('uid', $request->user['uid'])
  314. ->where('id', $post['id'])
  315. ->find();
  316. if (empty($data)) {
  317. return app('json')->fail('找不到订单信息');
  318. }
  319. //订单状态
  320. if ($data['status'] != 0) {
  321. return app('json')->fail('当前订单无法取消');
  322. }
  323. $order->where('id', $data['id'])->save(['status' => -1,]);
  324. (new OrderInfo)->where('o_id', $data['id'])->save(['status' => -1]);
  325. return app('json')->success(['msg' => '取消成功']);
  326. }
  327. }