问题说明:配送员送货扫核销码提示没有核销权限,目前好像必须是店员+配送员身份才能核销,既然配送员是单独添加的,那配送员就应该单独设置核销权限开关,要不配送给消费者就没办法显示送达。
修改文件:app/services/order/store/WriteOffOrderServices.php
修改方法:checkWriteoffAuth()
public function checkWriteoffAuth(int $id, int $oid, string $userType = 'user', string $orderType = 'order', $orderInfo = [])
{
if (!$id && !$oid) {
throw new ValidateException('核销单不存在');
}
if (!$orderInfo) {
switch ($orderType) {
case 'order'://订单
$orderInfo = $this->dao->getOne(['id' => $oid, 'is_del' => 0], '*', ['user', 'pink']);
break;
case 'reservation'://预约单
/** @var StoreReservationOrderServices $reservationOrderService */
$reservationOrderService = app()->make(StoreReservationOrderServices::class);
$orderInfo = $reservationOrderService->getReservationOrderInfo(0, (int)$id);
break;
}
}
if (!$orderInfo) {
throw new ValidateException('核销单不存在');
}
$storeId = $orderInfo['store_id'] ?? 0;
$isAuth = false;
$auth = 0;
try {
switch ($userType) {
case 'admin'://超级管理员
$isAuth = true;
break;
case 'kefu'://平台客服
/** @var StoreServiceServices $storeService */
$storeService = app()->make(StoreServiceServices::class);
$userService = $storeService->checkoutIsService(['uid' => $id, 'status' => 1, 'account_status' => 1, 'customer' => 1]);
if ($userService) {//平台客服
$isAuth = true;
$auth = 1;
}
break;
case 'user'://移动端用户
/** @var StoreServiceServices $storeService */
$storeService = app()->make(StoreServiceServices::class);
$userService = $storeService->checkoutIsService(['uid' => $id, 'status' => 1, 'account_status' => 1, 'customer' => 1]);
if ($userService) {//平台客服
$isAuth = true;
$auth = 1;
} else {
try {
/** @var SystemStoreStaffServices $storeStaffServices */
$storeStaffServices = app()->make(SystemStoreStaffServices::class);
$staff = $storeStaffServices->getStaffInfoByUid($id);
} catch (\Throwable $e){
$staff = [];
}
//店员存在 && 开启核销权限 && 订单是前端门店的
if ($staff && $staff['verify_status'] == 1 && $staff['store_id'] == $storeId) {
$isAuth = true;
$auth = 4;
} else {//配送员
/** @var DeliveryServiceServices $deliverServiceServices */
$deliverServiceServices = app()->make(DeliveryServiceServices::class);
$deliver = $deliverServiceServices->getDeliveryInfoByUid($id);
if (in_array($orderInfo['shipping_type'], [1, 3]) && $deliver && $orderInfo['delivery_type'] == 'send' && $orderInfo['delivery_uid'] == $id) {
$isAuth = true;
$auth = 2;
}
}
}
break;
case 'store'://门店核销
case 'cashier'://收银员
if ($id) {//传入id 就验证店员权限,不传默认门店后台管理员操作
//验证店员
/** @var SystemStoreStaffServices $storeStaffServices */
$storeStaffServices = app()->make(SystemStoreStaffServices::class);
$info = $storeStaffServices->getStaffInfo($id);
//店员存在 && 开启核销权限 && 订单是前端门店的
if ($info && $info['verify_status'] == 1 && $info['store_id'] == $storeId) {
$isAuth = true;
}
} else {
$isAuth = true;
}
$auth = 4;
break;
}
} catch (\Throwable $e) {
}
if (!$isAuth) {
throw new ValidateException('您无权限核销此订单,请联系管理员');
}
return $auth;
}
修改文件:app/services/order/store/WriteOffOrderServices.php
修改方法:checkUserAuth()
public function checkUserAuth(int $uid)
{
$auth = [];
$store_id = 0;
/** @var StoreServiceServices $storeService */
$storeService = app()->make(StoreServiceServices::class);
$userService = $storeService->checkoutIsService(['uid' => $uid, 'status' => 1, 'account_status' => 1, 'customer' => 1]);
if ($userService) {
$auth[] = 1;
}
try {
/** @var DeliveryServiceServices $deliverServiceServices */
$deliverServiceServices = app()->make(DeliveryServiceServices::class);
$info = $deliverServiceServices->getDeliveryInfoByUid($uid);
if ($info) {
$auth[] = 2;
}
} catch (\Throwable $e) {
}
try {
/** @var SystemStoreStaffServices $storeStaffServices */
$storeStaffServices = app()->make(SystemStoreStaffServices::class);
$info = $storeStaffServices->getStaffInfoByUid($uid);
if ($info && $info['verify_status'] == 1) {
$auth[] = 4;
$store_id = $info['store_id'];
}
} catch (\Throwable $e) {
}
return [$auth, $store_id];
}