核销
This commit is contained in:
parent
df785c38c9
commit
522b6ec6a2
@ -8,6 +8,7 @@ use app\api\logic\order\OrderLogic;
|
|||||||
use app\api\controller\BaseApiController;
|
use app\api\controller\BaseApiController;
|
||||||
use app\api\lists\order\OrderList;
|
use app\api\lists\order\OrderList;
|
||||||
use app\api\service\WechatUserService;
|
use app\api\service\WechatUserService;
|
||||||
|
use app\api\validate\OrderValidate;
|
||||||
use app\common\enum\PayEnum;
|
use app\common\enum\PayEnum;
|
||||||
use app\common\logic\PaymentLogic;
|
use app\common\logic\PaymentLogic;
|
||||||
use app\common\logic\PayNotifyLogic;
|
use app\common\logic\PayNotifyLogic;
|
||||||
@ -113,7 +114,6 @@ class OrderController extends BaseApiController
|
|||||||
*/
|
*/
|
||||||
public function createOrder()
|
public function createOrder()
|
||||||
{
|
{
|
||||||
|
|
||||||
$cartId = (array)$this->request->post('cart_id', []);
|
$cartId = (array)$this->request->post('cart_id', []);
|
||||||
$store_id = (array)$this->request->post('store_id', 0);
|
$store_id = (array)$this->request->post('store_id', 0);
|
||||||
$pay_type = (int)$this->request->post('pay_type');
|
$pay_type = (int)$this->request->post('pay_type');
|
||||||
@ -368,4 +368,18 @@ class OrderController extends BaseApiController
|
|||||||
return $this->success('添加成功');
|
return $this->success('添加成功');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//核销
|
||||||
|
public function writeoff_order()
|
||||||
|
{
|
||||||
|
$params = (new OrderValidate())->post()->goCheck('check');
|
||||||
|
$userId = $this->request->userId;
|
||||||
|
$res = OrderLogic::writeOff($params,$userId);
|
||||||
|
if ($res) {
|
||||||
|
return $this->success('核销成功');
|
||||||
|
}
|
||||||
|
return $this->fail('核销失败');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -2,16 +2,12 @@
|
|||||||
|
|
||||||
namespace app\api\logic\order;
|
namespace app\api\logic\order;
|
||||||
|
|
||||||
|
use app\common\enum\OrderEnum;
|
||||||
use app\common\enum\PayEnum;
|
use app\common\enum\PayEnum;
|
||||||
|
use app\common\enum\YesNoEnum;
|
||||||
use app\common\logic\BaseLogic;
|
use app\common\logic\BaseLogic;
|
||||||
use app\common\model\goods\Goods;
|
|
||||||
use app\common\model\goods\Unit;
|
|
||||||
use app\common\model\merchant\Merchant;
|
use app\common\model\merchant\Merchant;
|
||||||
use app\common\model\opurchase\Opurchaseclass;
|
|
||||||
use app\common\model\opurchase\Opurchaseinfo;
|
|
||||||
use app\common\model\order\Cart;
|
use app\common\model\order\Cart;
|
||||||
use app\common\model\retail\Cashierclass;
|
|
||||||
use app\common\model\retail\Cashierinfo;
|
|
||||||
use app\common\model\store_branch_product\StoreBranchProduct;
|
use app\common\model\store_branch_product\StoreBranchProduct;
|
||||||
use app\common\model\store_order\StoreOrder;
|
use app\common\model\store_order\StoreOrder;
|
||||||
use app\common\model\store_order_cart_info\StoreOrderCartInfo;
|
use app\common\model\store_order_cart_info\StoreOrderCartInfo;
|
||||||
@ -23,6 +19,7 @@ use app\common\model\user\UserAddress;
|
|||||||
use app\Request;
|
use app\Request;
|
||||||
use support\Log;
|
use support\Log;
|
||||||
use taoser\exception\ValidateException;
|
use taoser\exception\ValidateException;
|
||||||
|
use think\Exception;
|
||||||
use think\facade\Db;
|
use think\facade\Db;
|
||||||
use Yansongda\Pay\Event\PayEnd;
|
use Yansongda\Pay\Event\PayEnd;
|
||||||
|
|
||||||
@ -61,6 +58,7 @@ class OrderLogic extends BaseLogic
|
|||||||
$cart_select[$k]['product_id'] = $find['goods'];
|
$cart_select[$k]['product_id'] = $find['goods'];
|
||||||
$cart_select[$k]['old_cart_id'] = implode(',',$cartId);
|
$cart_select[$k]['old_cart_id'] = implode(',',$cartId);
|
||||||
$cart_select[$k]['cart_num'] = $v['cart_num'];
|
$cart_select[$k]['cart_num'] = $v['cart_num'];
|
||||||
|
$cart_select[$k]['verify_code'] = $params['verify_code'];
|
||||||
//理论上每笔都是拆分了
|
//理论上每笔都是拆分了
|
||||||
// $cart_select[$k]['name'] = $find['store_name'];
|
// $cart_select[$k]['name'] = $find['store_name'];
|
||||||
// $cart_select[$k]['imgs'] = $find['image'];
|
// $cart_select[$k]['imgs'] = $find['image'];
|
||||||
@ -94,6 +92,8 @@ class OrderLogic extends BaseLogic
|
|||||||
*/
|
*/
|
||||||
static public function createOrder($cartId, $addressId, $user = null, $params = [])
|
static public function createOrder($cartId, $addressId, $user = null, $params = [])
|
||||||
{
|
{
|
||||||
|
$verify_code = generateUniqueVerificationCode();
|
||||||
|
$params['verify_code'] = $verify_code;
|
||||||
$orderInfo = self::cartIdByOrderInfo($cartId, $addressId, $user, $params);
|
$orderInfo = self::cartIdByOrderInfo($cartId, $addressId, $user, $params);
|
||||||
if(!$orderInfo){
|
if(!$orderInfo){
|
||||||
return false;
|
return false;
|
||||||
@ -113,6 +113,7 @@ class OrderLogic extends BaseLogic
|
|||||||
$_order['real_name'] = $user['real_name'];
|
$_order['real_name'] = $user['real_name'];
|
||||||
$_order['mobile'] = $user['mobile'];
|
$_order['mobile'] = $user['mobile'];
|
||||||
$_order['pay_type'] = $user['pay_type'];
|
$_order['pay_type'] = $user['pay_type'];
|
||||||
|
$_order['verify_code'] = $verify_code;
|
||||||
|
|
||||||
if($addressId>0){
|
if($addressId>0){
|
||||||
$address=UserAddress::where(['address_id'=>$addressId,'uid'=>Request()->userId])->find();
|
$address=UserAddress::where(['address_id'=>$addressId,'uid'=>Request()->userId])->find();
|
||||||
@ -396,4 +397,58 @@ class OrderLogic extends BaseLogic
|
|||||||
}
|
}
|
||||||
return $find;
|
return $find;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//核销
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param $params
|
||||||
|
* @param $uid
|
||||||
|
* @return bool
|
||||||
|
* @throws \think\db\exception\DataNotFoundException
|
||||||
|
* @throws \think\db\exception\DbException
|
||||||
|
* @throws \think\db\exception\ModelNotFoundException
|
||||||
|
* @author: codeliu
|
||||||
|
* @Time: 2024/6/3 22:42
|
||||||
|
*/
|
||||||
|
public static function writeOff($params,$uid): bool
|
||||||
|
{
|
||||||
|
$data = StoreOrderCartInfo::where([
|
||||||
|
'oid'=>$params['order_id'],
|
||||||
|
'verify_code'=>$params['verify_code'],
|
||||||
|
'uid'=>$uid
|
||||||
|
])->select()->toArray();
|
||||||
|
if (empty($data)){
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
Db::startTrans();
|
||||||
|
try {
|
||||||
|
$newArr = [];
|
||||||
|
$oid = [];
|
||||||
|
foreach ($data as $k =>$value){
|
||||||
|
$oid [] = $value['oid'];
|
||||||
|
$newArr[$k]['writeoff_time'] = time();
|
||||||
|
$newArr[$k]['is_writeoff'] = YesNoEnum::YES;
|
||||||
|
$newArr[$k]['update_time'] = time();
|
||||||
|
}
|
||||||
|
(new StoreOrderCartInfo())->saveAll($newArr);
|
||||||
|
$oidArr = array_values(array_unique($oid));
|
||||||
|
StoreOrder::whereIn('id',$oidArr)
|
||||||
|
->update([
|
||||||
|
'status' => OrderEnum::RECEIVED_GOODS,
|
||||||
|
'update_time' => time(),
|
||||||
|
]);
|
||||||
|
Db::commit();
|
||||||
|
return true;
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
Db::rollback();
|
||||||
|
self::setError($e->getMessage());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
48
app/api/validate/OrderValidate.php
Normal file
48
app/api/validate/OrderValidate.php
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace app\api\validate;
|
||||||
|
use app\common\validate\BaseValidate;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 订单验证器
|
||||||
|
* Class OrderValidate
|
||||||
|
* @package app\admin\validate\order
|
||||||
|
*/
|
||||||
|
class OrderValidate extends BaseValidate
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置校验规则
|
||||||
|
* @var string[]
|
||||||
|
*/
|
||||||
|
protected $rule = [
|
||||||
|
'order_id' => 'require|number',
|
||||||
|
'verify_code' => 'require',
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 参数描述
|
||||||
|
* @var string[]
|
||||||
|
*/
|
||||||
|
protected $field = [
|
||||||
|
'order_id' => '订单',
|
||||||
|
'verify_code' => '验证码',
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @notes 添加场景
|
||||||
|
* @return OrderValidate
|
||||||
|
* @author likeadmin
|
||||||
|
* @date 2024/04/24 10:37
|
||||||
|
*/
|
||||||
|
public function sceneCheck()
|
||||||
|
{
|
||||||
|
return $this->only(['order_id','verify_code']);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -39,6 +39,14 @@ class OrderEnum
|
|||||||
const EXPENDITURE =0;
|
const EXPENDITURE =0;
|
||||||
const INCOME =1;
|
const INCOME =1;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 状态
|
||||||
|
* @RECEIVED_GOODS 已收货
|
||||||
|
*/
|
||||||
|
const RECEIVED_GOODS = 2;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 账户类型
|
* 账户类型
|
||||||
* @USER 用户
|
* @USER 用户
|
||||||
|
@ -342,3 +342,21 @@ if (!function_exists('setUnique')) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!function_exists('generateUniqueVerificationCode')) {
|
||||||
|
function generateUniqueVerificationCode() {
|
||||||
|
// 获取当前时间的毫秒部分
|
||||||
|
list($msec, $sec) = explode(' ', microtime());
|
||||||
|
$msectime = number_format((floatval($msec) + floatval($sec)) * 1000, 0, '', '');
|
||||||
|
|
||||||
|
// 生成一个随机数作为核销码的后缀
|
||||||
|
$randomNumber = mt_rand(10000000, 99999999); // 假设核销码是8位数
|
||||||
|
|
||||||
|
// 将前缀、毫秒时间戳和随机数连接起来
|
||||||
|
$type = rand(1, 10); // 生成一个1-10之间的随机数作为前缀
|
||||||
|
return $type . $msectime . $randomNumber;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user