|
|
@@ -53,7 +53,7 @@ class Order extends Api
|
|
|
$order_arr['price'] = $order_info->price;
|
|
|
$order_arr['product_id']= $params['product_id'];
|
|
|
$order_arr['area_id'] = $item;
|
|
|
- $productOrder::setCreateOrder($params['order_id'], $order_arr, $productOrder::Popular, $this->auth->id, 0, getOrderSN('R'), 0);
|
|
|
+ $productOrder::setCreateOrder($params['order_id'], $order_arr, $productOrder::Popular, $this->auth->id, 0, getOrderSN('R'), 0, $order_info->price);
|
|
|
//修改区域状态
|
|
|
$productArea->where('id', $item)->setField('status', ProductLists::STOP);
|
|
|
}
|
|
|
@@ -71,7 +71,7 @@ class Order extends Api
|
|
|
}
|
|
|
|
|
|
//更新Rwa持有数量
|
|
|
- $userModel::updateForRwaNum($this->auth->id, $this->auth->parent_id, $areaNum, '+');
|
|
|
+ if($order_info->price > config('min_rwa_price')) $userModel::updateForRwaNum($this->auth->id, $this->auth->parent_id, $areaNum, '+');
|
|
|
//扣除库存
|
|
|
if(($order_info->stock - $areaNum) == 0 || time() >= $order_info->end_time) $order_info->status= $productPopular::STOP;
|
|
|
$order_info->num += $areaNum;
|
|
|
@@ -91,22 +91,29 @@ class Order extends Api
|
|
|
/**
|
|
|
* 提货订单
|
|
|
*/
|
|
|
- public function pickupOrder(UserArea $userArea, ProductOrder $productOrder, UserModel $userModel)
|
|
|
+ public function pickupOrder(UserArea $userArea, ProductOrder $productOrder, UserModel $userModel, LedgerWalletModel $ledgerWalletModel)
|
|
|
{
|
|
|
$params = $this->request->post();
|
|
|
$validate = \think\Loader::validate('Order');
|
|
|
if(!$validate->scene('pick')->check($params)) $this->error($validate->getError());
|
|
|
$order_info = $productOrder->where('id', $params['order_id'])->find();
|
|
|
if(empty($order_info)) $this->error( __("参数有误,无可用产品"));
|
|
|
-
|
|
|
// 启动事务
|
|
|
Db::startTrans();
|
|
|
try {
|
|
|
+
|
|
|
+ $freight= getConfig('logistics_freight');
|
|
|
+ $amount = $ledgerWalletModel::getWalletChaBao($this->auth->id);
|
|
|
+ if(bccomp($freight, $amount, 2) > 0) throw new Exception(__("余额不足请前往充值"), 15001);
|
|
|
+
|
|
|
// 生成订单
|
|
|
- $userArea->create(['name'=>$params['name'], 'phone'=>$params['phone'],'address'=>$params['address'],'order_id'=>$params['order_id']]);
|
|
|
+ $userArea->create(['name'=>$params['name'], 'type_id'=>$userArea::TakeAdders, 'phone'=>$params['phone'],'address'=>$params['address'],'order_id'=>$params['order_id']]);
|
|
|
|
|
|
//扣除Rwa数量
|
|
|
- $userModel::updateForRwaNum($order_info->user_id, $userModel::getByParentId($order_info->user_id), 1, '-');
|
|
|
+ if($order_info->popular_price > config('min_rwa_price')) $userModel::updateForRwaNum($order_info->user_id, $userModel::getByParentId($order_info->user_id), 1, '-');
|
|
|
+
|
|
|
+ //扣除运费
|
|
|
+ $ledgerWalletModel->changeWalletAccount($this->auth->parent_id, Asset::TOKEN, $freight, $ledgerWalletModel::Freight, $this->auth->id);
|
|
|
|
|
|
$order_info->status= $productOrder::Shipped;
|
|
|
$order_info->save();
|
|
|
@@ -175,24 +182,27 @@ class Order extends Api
|
|
|
$chabao = $ledgerWalletModel::getWalletChaBao($this->auth->id);
|
|
|
if(bccomp($order_info['price'], $chabao, 2) > 0) throw new Exception(__("余额不足请前往充值"), 15001);
|
|
|
|
|
|
+ //抢购订单
|
|
|
+ $popular_order = $productOrder->where('id', $order_info['order_id'])->find();
|
|
|
// 生成订单
|
|
|
- $productOrder::setCreateOrder($params['order_id'], $order_info, $productOrder::Transfer, $this->auth->id, $order_info['user_id'], getOrderSN('Z'), $order_info['fees']);
|
|
|
+ $productOrder::setCreateOrder($params['order_id'], $order_info, $productOrder::Transfer, $this->auth->id, $order_info['user_id'], getOrderSN('Z'), $order_info['fees'], $popular_order->popular_price);
|
|
|
|
|
|
//扣除余额记录
|
|
|
$ledgerWalletModel->changeWalletAccount($this->auth->id, Asset::TOKEN, -$order_info['price'], $ledgerWalletModel::Payment, $order_info['user_id']);
|
|
|
|
|
|
- //扣除Rwa有效
|
|
|
- $userModel::updateForRwaNum($order_info['user_id'], $userModel::getByParentId($order_info['user_id']), 1, '-');
|
|
|
+ //扣除Rwa有效
|
|
|
+ if($popular_order->popular_price > config('min_rwa_price')) $userModel::updateForRwaNum($order_info['user_id'], $userModel::getByParentId($order_info['user_id']), 1, '-');
|
|
|
|
|
|
//增加转让人余额
|
|
|
$amount = bcsub($order_info['price'], $order_info['fees'], 2);
|
|
|
$ledgerWalletModel->changeWalletAccount($order_info['user_id'], Asset::TOKEN, $amount, $ledgerWalletModel::Receive, $this->auth->id);
|
|
|
|
|
|
//增加Rwa有效
|
|
|
- $userModel::updateForRwaNum($this->auth->id, $this->auth->parent_id, 1, '+');
|
|
|
+ if($popular_order->popular_price > config('min_rwa_price')) $userModel::updateForRwaNum($this->auth->id, $this->auth->parent_id, 1, '+');
|
|
|
|
|
|
//修改原订单状态
|
|
|
- $productOrder->where('id', $order_info['order_id'])->setField('status', $productOrder::Closure);
|
|
|
+ $popular_order->status->$productOrder::Closure;
|
|
|
+ $popular_order->save();
|
|
|
//修改状态
|
|
|
$order_info->status = $productTransfer::STOP;
|
|
|
$order_info->save();
|
|
|
@@ -225,16 +235,16 @@ class Order extends Api
|
|
|
if(bccomp($fees, $chabao, 2) > 0) throw new Exception(__("余额不足请前往充值"), 15001);
|
|
|
|
|
|
//添加记录
|
|
|
- $productOrder::setCreateOrder($params['order_id'], $order_info, $productOrder::Giveaway, $user['id'], $this->auth->id, getOrderSN('G'), $fees);
|
|
|
+ $productOrder::setCreateOrder($params['order_id'], $order_info, $productOrder::Giveaway, $user['id'], $this->auth->id, getOrderSN('G'), $fees, $order_info->popular_price);
|
|
|
|
|
|
//对方Rwa+1
|
|
|
- $userModel::updateForRwaNum($user['id'], $userModel::getByParentId($user['id']), 1, '+');
|
|
|
+ if($order_info->popular_price > config('min_rwa_price')) $userModel::updateForRwaNum($user['id'], $userModel::getByParentId($user['id']), 1, '+');
|
|
|
|
|
|
//扣除手续费
|
|
|
$ledgerWalletModel->changeWalletAccount($this->auth->id, Asset::TOKEN, -$fees, $ledgerWalletModel::Giveaway, $user['id']);
|
|
|
|
|
|
//扣除Rwa有效-1
|
|
|
- $userModel::updateForRwaNum($this->auth->id, $this->auth->parent_id, 1, '-');
|
|
|
+ if($order_info->popular_price > config('min_rwa_price')) $userModel::updateForRwaNum($this->auth->id, $this->auth->parent_id, 1, '-');
|
|
|
|
|
|
//修改:类型状态
|
|
|
$order_info->type_id= $productOrder::Giveaway;
|
|
|
@@ -269,7 +279,7 @@ class Order extends Api
|
|
|
$productTransfer::where('order_id',$params['order_id'])->setField('status', $productTransfer::STOP);
|
|
|
|
|
|
//新增记录
|
|
|
- $productOrder::setCreateOrder($order_info['order_id'], $order_info, $productOrder::Popular, $order_info['user_id'], $order_info['from_user'], getOrderSN('R'), 0);
|
|
|
+ $productOrder::setCreateOrder($order_info['order_id'], $order_info, $productOrder::Popular, $order_info['user_id'], $order_info['from_user'], getOrderSN('R'), 0, $order_info->popular_pric);
|
|
|
|
|
|
//修改:类型状态
|
|
|
$order_info->type_id= $productOrder::Transfer;
|
|
|
@@ -291,7 +301,7 @@ class Order extends Api
|
|
|
$order_id = $this->request->post('order_id'); // 订单id
|
|
|
if(empty($order_id)) $this->error(__("参数有误,无可用产品"));
|
|
|
|
|
|
- $tracking_no = $userArea->where('order_id', $order_id)->value('tracking_no');
|
|
|
+ $tracking_no = $userArea->where('order_id', $order_id)->where('type_id', $userArea::TakeAdders)->value('tracking_no');
|
|
|
if(empty($tracking_no)) $this->error(__("暂无物流信息"));
|
|
|
|
|
|
$this->success('ok', $tracking_no);
|