2024-06-24 11:52:30 +08:00
|
|
|
|
<?php
|
|
|
|
|
namespace app\admin\controller;
|
|
|
|
|
require_once(__DIR__.'/xlsxwriter.class.php');
|
|
|
|
|
|
|
|
|
|
use app\model\Admins;
|
|
|
|
|
use app\model\Backs;
|
2024-11-25 10:11:30 +08:00
|
|
|
|
use app\model\DyOrderProductAppointments;
|
|
|
|
|
use app\model\DyOrderProducts;
|
2024-06-24 11:52:30 +08:00
|
|
|
|
use app\model\Follows;
|
2024-12-06 16:34:59 +08:00
|
|
|
|
use app\model\OrderAfterSales;
|
2024-06-24 11:52:30 +08:00
|
|
|
|
use app\model\Orders;
|
|
|
|
|
use app\model\Logs;
|
2024-12-06 16:34:59 +08:00
|
|
|
|
use app\server\Douyin;
|
2024-11-25 10:11:30 +08:00
|
|
|
|
use app\server\DyApiService;
|
2024-09-10 09:41:07 +08:00
|
|
|
|
use app\server\ThirdApiService;
|
2024-07-11 15:38:18 +08:00
|
|
|
|
use app\server\Orders as ServerOrders;
|
2024-06-24 11:52:30 +08:00
|
|
|
|
use stdClass;
|
2024-06-24 20:58:23 +08:00
|
|
|
|
use support\Log;
|
2024-06-24 11:52:30 +08:00
|
|
|
|
use support\Redis;
|
|
|
|
|
use support\Request;
|
2024-06-26 15:38:38 +08:00
|
|
|
|
use think\facade\Db;
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
class OrderController extends base
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
public function index(Request $request) {
|
|
|
|
|
$sn = $request->get('sn');
|
|
|
|
|
$timetype = $request->get('timetype');
|
|
|
|
|
$times = $request->get('times');
|
|
|
|
|
$os_status = $request->get('os_status');
|
2024-10-13 17:01:24 +08:00
|
|
|
|
$isRefunded = $request->get('is_refunded', 0);
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$where = [];
|
|
|
|
|
if(!$request->admin->is_super) {
|
|
|
|
|
$where = [['admin_id','=', $request->admin->id]];
|
2024-09-04 15:23:30 +08:00
|
|
|
|
} else {
|
2024-09-04 21:03:05 +08:00
|
|
|
|
$where = [['admin_id', '>', 0]];
|
2024-06-24 11:52:30 +08:00
|
|
|
|
}
|
2024-10-13 17:01:24 +08:00
|
|
|
|
$where[] = ['is_refunded', '=', $isRefunded];
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
if($sn) {
|
|
|
|
|
$where[] = ['sn','=', $sn];
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-08 09:56:28 +08:00
|
|
|
|
// if (in_array($appointment_status, [0, 1])) {
|
|
|
|
|
// $where[] = ['appointment_status', '=', $appointment_status];
|
|
|
|
|
// }
|
|
|
|
|
|
2024-11-14 10:58:30 +08:00
|
|
|
|
switch ($request->get('order_by')) {
|
|
|
|
|
case 'verify_date_asc':
|
|
|
|
|
$orderBy['verification_date'] = 'asc';
|
|
|
|
|
break;
|
|
|
|
|
case 'verify_date_desc':
|
|
|
|
|
$orderBy['verification_date'] = 'desc';
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
$orderBy['create_at'] = 'desc';
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$status = $request->get('status', null);
|
|
|
|
|
|
2024-08-08 21:08:23 +08:00
|
|
|
|
$query = Orders::attimes($timetype, $times)->with(['admin','anchor','backs', 'mobileInfo'])->where($where)
|
2024-11-14 10:58:30 +08:00
|
|
|
|
->order($orderBy);
|
2024-06-28 17:30:56 +08:00
|
|
|
|
|
|
|
|
|
if($os_status) {
|
|
|
|
|
if ($os_status[0] == array_search(Orders::OSS[4],Orders::OSS)){
|
2024-08-28 16:12:16 +08:00
|
|
|
|
if (isset($os_status[1]) && is_numeric($os_status[1])) {
|
|
|
|
|
$query->whereRaw(Orders::AllOssStatusSql[$os_status[1]]);
|
|
|
|
|
}
|
2024-06-28 17:30:56 +08:00
|
|
|
|
}else{
|
2024-08-28 16:12:16 +08:00
|
|
|
|
if (isset($os_status[0]) && is_numeric($os_status[0])) {
|
|
|
|
|
$query->where('os', $os_status[0]);
|
|
|
|
|
}
|
|
|
|
|
if (isset($os_status[1]) && is_numeric($os_status[1])) {
|
|
|
|
|
$query->where('order_status', $os_status[1]);
|
|
|
|
|
}
|
2024-06-28 17:30:56 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2025-01-07 15:20:38 +08:00
|
|
|
|
if ($unUseType = $request->get('un_use_type', 0)) {
|
|
|
|
|
switch ($unUseType) {
|
|
|
|
|
case 1:
|
|
|
|
|
list($start, $end) = calculateDateRange(30, 60);
|
|
|
|
|
break;
|
|
|
|
|
case 2:
|
|
|
|
|
list($start, $end) = calculateDateRange(60, 80);
|
|
|
|
|
break;
|
|
|
|
|
case 3:
|
|
|
|
|
list($start, $end) = calculateDateRange(80, 365);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
list($start, $end) = calculateDateRange(30, 365);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
$query->whereBetweenTime('give_time', $start, $end);
|
|
|
|
|
$query->whereRaw(Orders::AllOssStatusSql[1]);
|
|
|
|
|
}
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-26 15:38:38 +08:00
|
|
|
|
if($status!=null && $status >= 0) {
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$query->where('status', $status);
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-08 09:56:28 +08:00
|
|
|
|
$appointment_status = $request->get('appointment_status', null);
|
|
|
|
|
if($appointment_status!=null && $appointment_status >= 0) {
|
|
|
|
|
$query->where('appointment_status', $appointment_status);
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$mobile = $request->get('mobile');
|
|
|
|
|
if($mobile){
|
2024-06-25 16:45:14 +08:00
|
|
|
|
$query->where('mobile','like', '%'.$mobile.'%');
|
2024-06-24 11:52:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-08-08 21:08:23 +08:00
|
|
|
|
$productName = $request->get('product_name');
|
|
|
|
|
if($productName){
|
|
|
|
|
$query->where('product_name','like', '%'.$productName.'%');
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$zhubo = $request->get('zhubo');
|
|
|
|
|
if($zhubo){
|
|
|
|
|
$zhubo_id = Admins::where('username', $zhubo)->value('id');
|
|
|
|
|
$query->where('zhubo', $zhubo_id);
|
|
|
|
|
}
|
2024-12-03 18:28:01 +08:00
|
|
|
|
try {
|
|
|
|
|
$admin = $request->get('admin');
|
|
|
|
|
if ($request->admin->is_franchisee == 1) {
|
|
|
|
|
$query->whereRaw(sprintf('admin_id in (select id from admins where pid = "%s")', $request->admin->id));
|
|
|
|
|
} elseif($admin){
|
|
|
|
|
$admin_id = Admins::where('username', $admin)->value('id');
|
|
|
|
|
$query->where('admin_id', $admin_id);
|
|
|
|
|
}
|
|
|
|
|
} catch (\Exception $exception) {
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
}
|
2024-10-14 09:06:23 +08:00
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$excel = $request->get('excel');
|
|
|
|
|
if($excel == 1) {
|
|
|
|
|
$orders = $query->select();
|
|
|
|
|
|
|
|
|
|
$writer = new \XLSXWriter();
|
|
|
|
|
$writer->writeSheetHeader('Sheet1', ['电话'=>'string','平台'=>'string','直播'=>'string','订单号'=>'string','下单时间'=>'string','状态'=>'string','跟进状态'=>'string',
|
|
|
|
|
'标题'=>'string','跟进备注'=>'string','联系人'=>'string','出行时间'=>'string','回来时间'=>'string',
|
|
|
|
|
'跟进时间'=>'string',
|
|
|
|
|
'总金额'=>'price','支付金额'=>'price','核销金额'=>'price','人数'=>'integer','跟单人'=>'string','主播'=>'string']);
|
|
|
|
|
|
|
|
|
|
foreach($orders as $order) {
|
|
|
|
|
$writer->writeSheetRow('Sheet1', [$order->mobile, $order->os_name, $order->is_zhibo, "$order->sn", date('Y-m-d H:i:s', intval($order->create_at/1000)),$order->order_status_name, $order->status_name,
|
|
|
|
|
$order->product_name, $order->remark, $order->contact, $order->travel_date, $order->travel_end,
|
|
|
|
|
$order->last_follow ? date('Y-m-d H:i:s', intval($order->last_follow/1000)):'',
|
|
|
|
|
$order->total_price/100, $order->actual_price/100, $order->asset_price/100, $order->quantity, $order->admin->username ?? '', $order->anchor->username ?? '']);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$file_name = "订单导出-".date('Ymd-His').".xlsx";
|
|
|
|
|
|
|
|
|
|
$response = response();
|
|
|
|
|
$c = $writer->writeToString();
|
|
|
|
|
$response->withHeaders([
|
|
|
|
|
'Content-Type' => 'application/force-download',
|
|
|
|
|
'Content-Disposition' => 'attachment; filename="'.$file_name.'"',
|
|
|
|
|
'Content-Transfer-Encoding' => 'binary',
|
|
|
|
|
'Cache-Control' => 'max-age=0',
|
|
|
|
|
])->withBody($c);
|
|
|
|
|
return $response;
|
|
|
|
|
// return;
|
|
|
|
|
}else{
|
|
|
|
|
$orders = $query->paginate($request->get('limit',10));
|
|
|
|
|
}
|
2025-01-07 15:32:39 +08:00
|
|
|
|
if ($unUseType > 0) {
|
|
|
|
|
Log::info('sql:' . $query->getLastSql());
|
|
|
|
|
}
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
foreach($orders as &$order) {
|
|
|
|
|
if(empty($order->personnel)) {
|
|
|
|
|
$order->personnel = new stdClass();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$list = $orders->visible(['admin' => ['username','name','avatar']])->hidden(['check_sn'])->append(['order_status_name','status_name','os_name']);
|
|
|
|
|
|
2024-08-09 15:21:06 +08:00
|
|
|
|
$localMobiles = [];
|
2024-08-08 21:08:23 +08:00
|
|
|
|
foreach ($list as &$value) {
|
|
|
|
|
$mobileInfo = $value['mobileInfo'] ?? '';
|
|
|
|
|
if (empty($value['mobileInfo'])) {
|
|
|
|
|
try {
|
2024-08-09 15:21:06 +08:00
|
|
|
|
if (isset($localMobiles[$value['mobile']])) {
|
|
|
|
|
// 防止重复查询第三方接口
|
|
|
|
|
$mobileInfo = $localMobiles[$value['mobile']];
|
|
|
|
|
} else {
|
2024-09-10 09:41:07 +08:00
|
|
|
|
$mobileInfo = (new ThirdApiService())->getMobileArea($value['mobile']);
|
2024-08-09 15:21:06 +08:00
|
|
|
|
$localMobiles[$value['mobile']] = $mobileInfo;
|
|
|
|
|
}
|
2024-08-08 21:08:23 +08:00
|
|
|
|
} catch (\Exception $exception) {
|
|
|
|
|
$mobileInfo = [];
|
|
|
|
|
Log::info('查询手机归属地失败:' . $exception->getMessage());
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-08-08 21:44:08 +08:00
|
|
|
|
$value['mobileInfo'] = $mobileInfo;
|
2024-11-25 17:18:00 +08:00
|
|
|
|
// $value['mobile'] = substr_replace($value['mobile'], '****', 3, 4);
|
2024-08-08 21:08:23 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$_oss = [];
|
|
|
|
|
foreach (Orders::OSS as $key=>$os) {
|
|
|
|
|
$_oss[$key] = ['label' => $os,'value' => $key];
|
|
|
|
|
if($key == 1) {
|
|
|
|
|
$statss = Orders::OrderStatus;
|
|
|
|
|
}elseif($key ==2) {
|
|
|
|
|
$statss = Orders::KuaishouStatus;
|
|
|
|
|
}elseif($key ==3) {
|
|
|
|
|
$statss = Orders::DouyinStatus;
|
2024-06-28 17:30:56 +08:00
|
|
|
|
}elseif ($key == 4) {
|
|
|
|
|
$statss = Orders::AllOssStatus;
|
2024-08-16 21:12:33 +08:00
|
|
|
|
}elseif($key ==5) {
|
|
|
|
|
$statss = Orders::DouyinStatus;
|
2024-09-02 17:41:24 +08:00
|
|
|
|
}elseif($key ==6) {
|
|
|
|
|
$statss = Orders::TongchengStatus;
|
2024-09-04 21:03:05 +08:00
|
|
|
|
}elseif($key ==6) {
|
|
|
|
|
$statss = Orders::OrderStatus;
|
2024-06-28 17:30:56 +08:00
|
|
|
|
}
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
$_ch = [];
|
|
|
|
|
foreach($statss as $k=>$v) {
|
|
|
|
|
$_ch[] = ['label' => $v,'value' => $k];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$_oss[$key]['children'] = $_ch;
|
|
|
|
|
}
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-08-16 21:46:15 +08:00
|
|
|
|
return $this->success($list,null,['timetype'=> Orders::timeType, 'oss' => array_values($_oss)]);
|
2024-06-24 11:52:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function all(Request $request) {
|
|
|
|
|
$sn = $request->get('sn');
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
if($sn) {
|
|
|
|
|
$where[] = ['sn','=', $sn];
|
|
|
|
|
}
|
|
|
|
|
$orders = Orders::with(['admin'])->where($where)->order('update_time','desc')->order('create_at','desc')->order('id','desc')->paginate($request->get('limit',10));
|
|
|
|
|
|
|
|
|
|
return $this->success($orders->visible(['admin' => ['username','name','avatar']])->hidden(['mobile','check_sn'])->append(['order_status_name','status_name','os_name']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function pub(Request $request) {
|
|
|
|
|
$orders = Orders::where('admin_id', 0)->order('create_at','desc')->order('id','desc')->paginate($request->get('limit',10));
|
|
|
|
|
|
|
|
|
|
return $this->success($orders->hidden(['mobile','check_sn'])->append(['order_status_name','os_name']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//公海领取订单
|
|
|
|
|
public function fish(Request $request) {
|
|
|
|
|
$id = $request->post('id');
|
|
|
|
|
if(empty($id) || intval($id) <=0) return $this->error(2001, '请提交id');
|
|
|
|
|
|
|
|
|
|
$order = Orders::find($id);
|
|
|
|
|
if($order->admin_id > 0 ) return $this->error(2002, '订单没有找到或者已经转移到其他人');
|
|
|
|
|
|
|
|
|
|
try{
|
|
|
|
|
Orders::fish($order->id, $request->admin->id);
|
|
|
|
|
return $this->success(null);
|
|
|
|
|
}catch(\Exception $e){
|
|
|
|
|
return $this->error(2003, '公海获取订单失败,订单没有找到或者已经转移到其他人');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function info(Request $request) {
|
|
|
|
|
$id = $request->get('id');
|
|
|
|
|
|
|
|
|
|
if(empty($id) || intval($id) <=0) return $this->error(2001, '请提交id');
|
|
|
|
|
|
|
|
|
|
$where[] = ['id','=',$id];
|
|
|
|
|
|
|
|
|
|
if($request->admin->is_super == 0) {
|
|
|
|
|
$where[] = ['admin_id','=',$request->admin->id];
|
|
|
|
|
}
|
2024-12-02 18:43:20 +08:00
|
|
|
|
$item = Orders::where($where)->with(['follow.admin','finance', 'dyOrderAppointments'])->find();
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
if(empty($item)) {
|
|
|
|
|
return $this->error(2002, '订单没有找到或者已经转移到其他人');
|
|
|
|
|
}
|
|
|
|
|
Logs::see($item->id, $request->admin->id);
|
|
|
|
|
|
|
|
|
|
if(empty($item->personnel)) {
|
|
|
|
|
$item->personnel = new stdClass();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $this->success($item->append(['order_status_name','os_name']));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//核销,跟单
|
|
|
|
|
public function save(Request $request) {
|
|
|
|
|
$id = $request->post('id');
|
|
|
|
|
$next_follow = $request->post('next_follow');
|
|
|
|
|
$check_sn = $request->post('check_sn');
|
|
|
|
|
$desc = $request->post('desc');
|
|
|
|
|
$status = $request->post('status');
|
|
|
|
|
$is_wechat = $request->post('is_wechat');
|
|
|
|
|
$personnel = $request->post('personnel');
|
|
|
|
|
$travel_date = $request->post('travel_date');
|
|
|
|
|
$travel_end = $request->post('travel_end');
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(empty($desc) || empty($status)) return $this->error(2004, '跟进说明需要填写!');
|
|
|
|
|
if(empty($personnel)) return $this->error(2004, '人员情况需要填写!');
|
|
|
|
|
if(empty($travel_date)) return $this->error(2004, '出游时间需要填写!');
|
2024-09-05 15:56:58 +08:00
|
|
|
|
if (in_array($status, [0, 1])){
|
2024-06-27 14:09:12 +08:00
|
|
|
|
if(empty($next_follow)) return $this->error(2004, '下次跟进时间需要填写!');
|
2024-06-27 17:34:53 +08:00
|
|
|
|
}
|
|
|
|
|
if ($status == 2){
|
|
|
|
|
$next_follow = '';
|
|
|
|
|
if(empty($travel_end)) return $this->error(2004, '返回日期需要填写!');
|
|
|
|
|
if(empty($check_sn)) return $this->error(2004, '核销码需要填写!');
|
2024-06-27 14:09:12 +08:00
|
|
|
|
}
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
$lock = 'Travel:Order:'.$id.':lock';
|
|
|
|
|
$back = Redis::set($lock, $request->admin->id, 'EX', 6, 'NX');
|
|
|
|
|
if(!$back) return $this->error(2005, '锁定失败');
|
|
|
|
|
|
|
|
|
|
$item = Orders::where('id', $id)->where('admin_id', $request->admin->id)->find();
|
|
|
|
|
if(empty($item)) return $this->error(2006, '订单不存在');
|
|
|
|
|
if($item->admin_id != $request->admin->id) return $this->error(2007, '订单已经发生转移');
|
|
|
|
|
|
2024-06-29 13:40:15 +08:00
|
|
|
|
//if(!empty($travel_date) && empty($travel_end)) return $this->error(2008, '核销的订单请填写出行和返回时间');
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
Follows::create([
|
|
|
|
|
'admin_id' => $request->admin->id,
|
|
|
|
|
'order_id' => $item->id,
|
|
|
|
|
'status' => $status,
|
|
|
|
|
'desc' => $desc
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
//放弃跟进
|
|
|
|
|
// if($status == 4) {
|
|
|
|
|
// $item->status = 0;
|
|
|
|
|
// $item->admin_id = 0;
|
|
|
|
|
// $item->remark = $desc;
|
|
|
|
|
// $item->save();
|
|
|
|
|
// return $this->success($item);
|
|
|
|
|
// }else{
|
2024-11-15 09:47:44 +08:00
|
|
|
|
// 记录核销日期
|
|
|
|
|
if ($status == 2 && $item->status !=2) {
|
|
|
|
|
$item->verification_date = date('Y-m-d H:i:s');
|
|
|
|
|
}
|
2024-06-24 11:52:30 +08:00
|
|
|
|
//修改状态
|
|
|
|
|
$item->check_sn = $check_sn;
|
|
|
|
|
$item->status = $status;
|
|
|
|
|
!empty($travel_date) && empty($item->travel_date) ? $item->travel_date = date('Y-m-d', strtotime($travel_date)) : null;
|
|
|
|
|
!empty($travel_end) && empty($item->travel_end) ? $item->travel_end = date('Y-m-d', strtotime($travel_end)) : null;
|
|
|
|
|
$item->personnel = json_encode($personnel);
|
|
|
|
|
$item->is_wechat = $is_wechat? 1: 0;
|
|
|
|
|
$item->last_follow = microtime(true) * 1000;
|
|
|
|
|
$item->next_follow = strtotime($next_follow??'') * 1000;
|
|
|
|
|
$item->remark = $desc;
|
|
|
|
|
|
|
|
|
|
$back = $item->save();
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
if($back) {
|
|
|
|
|
if ($item->check_sn) {
|
|
|
|
|
//通过命令行核销订单
|
|
|
|
|
Redis::LPUSH('Travel:Order:check:lits',json_encode([
|
|
|
|
|
'id' => $item->id,
|
|
|
|
|
'check_sn' => $item->check_sn
|
|
|
|
|
]));
|
|
|
|
|
|
|
|
|
|
// 限制只被录入一次
|
|
|
|
|
$has = Logs::where('admin_id', $request->admin->id)->whereIN('action',[2,3])->where('check_sn',$check_sn)->find();
|
|
|
|
|
if(empty($has)) {
|
|
|
|
|
Logs::pass($item->id, $request->admin->id, $check_sn);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if($item->is_wechat > 0 ) {
|
|
|
|
|
$has = Logs::where('admin_id', $request->admin->id)->where('order_id', $item->id)->where('action', 5)->find();
|
|
|
|
|
if(empty($has)) {
|
|
|
|
|
Logs::wechat($item->id, $request->admin->id);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $this->success($item);
|
|
|
|
|
}else{
|
|
|
|
|
return $this->error(2008, '保存订单失败');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function pass(Request $request) {
|
|
|
|
|
$check_sn = $request->post('check_sn');
|
|
|
|
|
if(!is_numeric($check_sn)) return $this->error(2008, '格式错误');
|
|
|
|
|
|
|
|
|
|
$has = Orders::where('check_sn', $check_sn)->find();
|
|
|
|
|
if($has) {
|
|
|
|
|
return $this->error(2008, '核销码已经被使用了');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//限制只被录入一次
|
|
|
|
|
$has = Logs::where('admin_id', $request->admin->id)->whereIN('action',[2,3])->where('check_sn', $check_sn)->find();
|
|
|
|
|
if(empty($has)) {
|
|
|
|
|
Logs::pass2($request->admin->id, $check_sn);
|
|
|
|
|
}
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
//通过命令行核销订单
|
|
|
|
|
Redis::LPUSH('Travel:Order:check:lits',json_encode([
|
|
|
|
|
'admin_id' => $request->admin->id,
|
|
|
|
|
'check_sn' => $check_sn
|
|
|
|
|
]));
|
|
|
|
|
|
|
|
|
|
return $this->success(null,'提交成功');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//把订单拉回
|
|
|
|
|
public function backlist(Request $request) {
|
|
|
|
|
$sn = $request->get('sn');
|
|
|
|
|
$status = $request->get('status',null);
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-24 20:58:23 +08:00
|
|
|
|
$query = Backs::with(['into','outto','orders','apply'])->where(function($query) use($request) {
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$query->where('admin_id', $request->admin->id)->WhereOr('admin', $request->admin->id);
|
|
|
|
|
})->order('update_time','desc')->order('id','desc');
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
if($sn) {
|
|
|
|
|
$order_id = Orders::where('sn', $sn)->value('id');
|
|
|
|
|
$query->where('order_id', $order_id);
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-26 15:38:38 +08:00
|
|
|
|
if($status != null) {
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$query->where('status', $status);
|
|
|
|
|
}
|
2024-08-08 21:08:23 +08:00
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$backs = $query->paginate($request->get('limit',10));
|
|
|
|
|
foreach($backs as &$back){
|
2024-06-24 20:58:23 +08:00
|
|
|
|
if ($back->admin_id == $request->admin->id || $back->admin == $request->admin->id){
|
|
|
|
|
$back->self = 0;
|
|
|
|
|
if($back->apply_id == $request->admin->id) {
|
|
|
|
|
$back->self = 3;
|
|
|
|
|
}
|
|
|
|
|
}else{
|
2024-06-24 11:52:30 +08:00
|
|
|
|
$back->self = 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $this->success($backs->append(['order_status_name','os_name']),null, Orders::OSS);
|
|
|
|
|
}
|
|
|
|
|
|
2024-10-12 19:16:04 +08:00
|
|
|
|
// 批量流转出
|
|
|
|
|
public function backBatch(Request $request) {
|
|
|
|
|
$sn = $request->post('sn');
|
|
|
|
|
if (empty($sn) || !is_array($sn)) {
|
|
|
|
|
return $this->error(2001, '请选择流转的订单');
|
|
|
|
|
}
|
|
|
|
|
$toAdminId = $request->post('to_admin_id');
|
|
|
|
|
if (!$toAdminId) {
|
|
|
|
|
return $this->error(2001, '请选择流转的客服');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Orders::whereIn('sn', $sn)->update(['admin_id'=> $toAdminId]);
|
|
|
|
|
|
|
|
|
|
foreach ($sn as $value) {
|
|
|
|
|
$item = Orders::where('sn', $value)->find();
|
|
|
|
|
if($item->admin_id == $toAdminId) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Backs::create([
|
|
|
|
|
'order_id' => $item->id,
|
|
|
|
|
'admin_id' => $toAdminId,
|
|
|
|
|
'admin' => $item->admin_id,
|
|
|
|
|
'apply_id' => $request->admin->id,
|
|
|
|
|
'status' => 1
|
|
|
|
|
]);
|
2024-10-22 17:42:17 +08:00
|
|
|
|
Orders::where('sn', $value)->update(['admin_id'=> $toAdminId, 'update_time' => time()]);
|
2024-10-12 19:16:04 +08:00
|
|
|
|
// 发送短信
|
|
|
|
|
\app\server\Orders::sendOrderSms($toAdminId, $item);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $this->success(true);
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 11:52:30 +08:00
|
|
|
|
//把订单拉回
|
|
|
|
|
public function back(Request $request) {
|
|
|
|
|
$sn = $request->post('sn');
|
|
|
|
|
$os = $request->post('os');
|
2024-06-24 20:58:23 +08:00
|
|
|
|
$to_admin_id = $request->post('to_admin_id');
|
|
|
|
|
$admin_id = empty($to_admin_id) ? $request->admin->id : $to_admin_id;
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
if(empty($sn)) return $this->error(2001, '提交单号');
|
|
|
|
|
|
|
|
|
|
$item = Orders::where('sn', $sn)->where('os', $os)->find();
|
|
|
|
|
if(empty($item)) return $this->error(2002, '订单没有找到');
|
2024-06-24 20:58:23 +08:00
|
|
|
|
if($item->admin_id == $admin_id) return $this->error(2002, '订单已经在账号上,不需要再拉取!');
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
2024-06-26 15:38:38 +08:00
|
|
|
|
//管理员不用审批
|
|
|
|
|
$status = 0;
|
|
|
|
|
if ($request->admin->is_super == 1 || $request->admin->id == 1){
|
|
|
|
|
$status = 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$backs = [
|
2024-06-24 11:52:30 +08:00
|
|
|
|
'order_id' => $item->id,
|
2024-06-24 20:58:23 +08:00
|
|
|
|
'admin_id' => $admin_id,
|
|
|
|
|
'admin' => $item->admin_id,
|
2024-06-26 15:38:38 +08:00
|
|
|
|
'apply_id' => $request->admin->id,
|
|
|
|
|
'status' => $status
|
|
|
|
|
];
|
|
|
|
|
try {
|
|
|
|
|
Db::transaction(function() use ($backs,$item) {
|
|
|
|
|
Backs::create($backs);
|
|
|
|
|
Logs::todo($backs['order_id'], $backs['apply_id'], $backs['status'] == 1 ? 12 : 7,$item->sn);
|
|
|
|
|
|
|
|
|
|
if ($backs['status'] == 1){//管理员审批处理
|
|
|
|
|
Orders::where('id', $backs['order_id'])->where('admin_id', $backs['admin'])->update(['admin_id'=> $backs['admin_id']]);
|
|
|
|
|
$other = Backs::where('order_id', $backs['order_id'])->where('status', 0)->lock()->select();
|
|
|
|
|
foreach($other as $o) {
|
|
|
|
|
Backs::where('id', $o->id)->where('status', 0)->update(['status' => 3]);
|
|
|
|
|
Logs::todo($o->order_id, $o->admin, 10); //取消其他转单需求
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}catch (\Exception $e){
|
2024-06-24 11:52:30 +08:00
|
|
|
|
return $this->error(2003, '创建拉回记录失败了');
|
|
|
|
|
}
|
2024-06-26 15:38:38 +08:00
|
|
|
|
|
|
|
|
|
return $this->success(true);
|
2024-06-24 11:52:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function toBack(Request $request) {
|
|
|
|
|
$sn = $request->post('sn');
|
|
|
|
|
$os = $request->post('os');
|
2024-06-24 20:58:23 +08:00
|
|
|
|
$to_admin_id = $request->post('to_admin_id');
|
|
|
|
|
$admin_id = empty($to_admin_id) ? $request->admin->id : $to_admin_id;
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
if(empty($sn)) return $this->error(2001, '提交单号');
|
|
|
|
|
|
|
|
|
|
$item = Orders::where('sn', $sn)->where('os', $os)->find();
|
|
|
|
|
if(empty($item)) return $this->error(2002, '订单没有找到');
|
2024-06-24 20:58:23 +08:00
|
|
|
|
if($item->admin_id == $admin_id) return $this->error(2002, '订单已经在账号上,不需要再拉取!');
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
2024-06-26 15:38:38 +08:00
|
|
|
|
//管理员不用审批
|
|
|
|
|
$status = 0;
|
|
|
|
|
if ($request->admin->is_super == 1 || $request->admin->id == 1){
|
|
|
|
|
$status = 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$backs = [
|
2024-06-24 11:52:30 +08:00
|
|
|
|
'order_id' => $item->id,
|
2024-06-24 20:58:23 +08:00
|
|
|
|
'admin_id' => $admin_id,
|
|
|
|
|
'admin' => $item->admin_id,
|
2024-06-26 15:38:38 +08:00
|
|
|
|
'apply_id' => $request->admin->id,
|
|
|
|
|
'status' => $status
|
|
|
|
|
];
|
|
|
|
|
try {
|
|
|
|
|
Db::transaction(function() use ($backs,$item) {
|
|
|
|
|
Backs::create($backs);
|
|
|
|
|
Logs::todo($backs['order_id'], $backs['apply_id'], $backs['status'] == 1 ? 12 : 7,$item->sn);
|
|
|
|
|
|
|
|
|
|
if ($backs['status'] == 1){//管理员审批处理
|
|
|
|
|
Orders::where('id', $backs['order_id'])->where('admin_id', $backs['admin'])->update(['admin_id'=> $backs['admin_id']]);
|
|
|
|
|
$other = Backs::where('order_id', $backs['order_id'])->where('status', 0)->lock()->select();
|
|
|
|
|
foreach($other as $o) {
|
|
|
|
|
Backs::where('id', $o->id)->where('status', 0)->update(['status' => 3]);
|
|
|
|
|
Logs::todo($o->order_id, $o->admin, 10); //取消其他转单需求
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}catch (\Exception $e){
|
2024-06-24 11:52:30 +08:00
|
|
|
|
return $this->error(2003, '创建拉回记录失败了');
|
|
|
|
|
}
|
2024-06-26 15:38:38 +08:00
|
|
|
|
|
|
|
|
|
return $this->success(true);
|
2024-06-24 11:52:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 20:58:23 +08:00
|
|
|
|
/**
|
|
|
|
|
* 同意操作
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
2024-06-24 11:52:30 +08:00
|
|
|
|
public function backpass(Request $request) {
|
|
|
|
|
$id = $request->post('id', 0);
|
|
|
|
|
|
|
|
|
|
$item = Backs::where('id', $id)->find();
|
|
|
|
|
if($item->status != 0) return $this->error(2004, '记录已经处理了.');
|
2024-06-24 20:58:23 +08:00
|
|
|
|
if($item->admin != $request->admin->id && $item->admin != $item->apply_id) return $this->error(2005, '管理员错误');
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
Backs::change($item);
|
|
|
|
|
return $this->success('');
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '确认失败了');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 20:58:23 +08:00
|
|
|
|
/**
|
|
|
|
|
* 拒绝操作
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
2024-06-24 11:52:30 +08:00
|
|
|
|
public function backrefuse(Request $request) {
|
|
|
|
|
$id = $request->post('id', 0);
|
|
|
|
|
|
|
|
|
|
$item = Backs::where('id', $id)->find();
|
|
|
|
|
if(empty($item)) return $this->error(2004, '记录没有找到.');
|
|
|
|
|
if($item->status != 0) return $this->error(2004, '记录已经处理了.');
|
2024-06-24 20:58:23 +08:00
|
|
|
|
if($item->admin != $request->admin->id && $item->admin != $item->apply_id) return $this->error(2005, '管理员错误');
|
2024-06-24 11:52:30 +08:00
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
Backs::refuse($item);
|
|
|
|
|
return $this->success('');
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '确认失败了');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-24 20:58:23 +08:00
|
|
|
|
/**
|
|
|
|
|
* 取消操作
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
|
|
|
|
public function backcancel(Request $request)
|
|
|
|
|
{
|
|
|
|
|
$id = $request->post('id', 0);
|
|
|
|
|
|
|
|
|
|
$item = Backs::where('id', $id)->find();
|
|
|
|
|
if(empty($item)) return $this->error(2004, '记录没有找到.');
|
|
|
|
|
if($item->status != 0) return $this->error(2004, '记录已经处理了.');
|
|
|
|
|
if($item->admin != $request->admin->id && $item->admin == $item->apply_id) return $this->error(2005, '管理员错误');
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
Backs::cancel($item);
|
|
|
|
|
return $this->success('');
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '确认失败了');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-07-11 15:38:18 +08:00
|
|
|
|
/**
|
|
|
|
|
* 一键修复订单问题
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
|
|
|
|
public function oneClickRepair(Request $request)
|
|
|
|
|
{
|
|
|
|
|
try {
|
2024-07-29 15:22:30 +08:00
|
|
|
|
$ids = $request->post('id', 0);
|
|
|
|
|
$idArr = explode(',', $ids);
|
|
|
|
|
|
2024-07-11 15:38:18 +08:00
|
|
|
|
$flow = [];
|
2024-07-29 15:22:30 +08:00
|
|
|
|
foreach ($idArr as $id) {
|
|
|
|
|
Log::info('同步订单ID:' . $id);
|
2024-07-11 15:38:18 +08:00
|
|
|
|
|
2024-07-29 15:22:30 +08:00
|
|
|
|
$order = Orders::where('id', $id)->find();
|
|
|
|
|
|
|
|
|
|
if (empty($order)) {
|
2024-11-01 14:15:37 +08:00
|
|
|
|
return $this->success('同步成功');
|
2024-07-29 15:22:30 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 订单是待使用状态,先同步第三方状态
|
|
|
|
|
if (ServerOrders::isDaishiyong($order)) {
|
|
|
|
|
ServerOrders::syncFromThird($order);
|
|
|
|
|
$flow[] = "订单为待使用状态,已请求第三方进行同步。";
|
|
|
|
|
}
|
2024-07-11 15:38:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $this->success(implode("\n", $flow));
|
|
|
|
|
}catch(\Exception $e) {
|
2024-09-10 17:02:11 +08:00
|
|
|
|
Log::info(sprintf('oneClickRepair error:%s, %s, %s', $e->getMessage(), $e->getFile(), $e->getLine()) );
|
2024-11-25 17:35:04 +08:00
|
|
|
|
return $this->success([]);
|
2024-07-11 15:38:18 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-09-02 17:41:24 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 预约处理
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
|
*/
|
|
|
|
|
public function changeAppointmentStatus(Request $request)
|
|
|
|
|
{
|
|
|
|
|
try {
|
|
|
|
|
$ids = $request->post('id', 0);
|
|
|
|
|
$idArr = explode(',', $ids);
|
|
|
|
|
|
|
|
|
|
$flow = [];
|
|
|
|
|
foreach ($idArr as $id) {
|
|
|
|
|
Log::info('同步订单ID:' . $id);
|
|
|
|
|
|
|
|
|
|
$order = Orders::where('id', $id)->find();
|
|
|
|
|
|
|
|
|
|
if (empty($order)) {
|
|
|
|
|
return $this->error(2004, '记录没有找到.');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 订单是待使用状态,先同步第三方状态
|
|
|
|
|
$order['appointment_status'] = 2;
|
|
|
|
|
$order->save();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $this->success(implode("\n", $flow));
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '出错了:' . $e->getMessage());
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-11-25 10:11:30 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 获取预约信息
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
*/
|
|
|
|
|
public function getAppointInfo(Request $request) {
|
|
|
|
|
try {
|
|
|
|
|
$id = $request->get('id', 0);
|
|
|
|
|
$order = Orders::where('id', $id)->find();
|
|
|
|
|
if (empty($order)) {
|
|
|
|
|
return $this->error(2004, '记录没有找到.');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 抖音预约信息
|
|
|
|
|
$appoint = DyOrderProductAppointments::query()->where(['dy_order_id' => $order['sn']])->find();
|
|
|
|
|
return $this->success($appoint);
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '出错了:' . $e->getMessage());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 抖音确认订单
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
*/
|
|
|
|
|
public function dyOrderConfirm(Request $request) {
|
|
|
|
|
try {
|
|
|
|
|
$id = $request->post('id', 0);
|
|
|
|
|
$order = Orders::where('id', $id)->find();
|
|
|
|
|
if (empty($order)) {
|
|
|
|
|
return $this->error(2004, '记录没有找到.');
|
|
|
|
|
}
|
|
|
|
|
// 1:接单 2:拒单
|
2024-12-02 18:43:20 +08:00
|
|
|
|
if (!$request->post('confirm_result') || !in_array($request->post('confirm_result'), [1, 2])) {
|
|
|
|
|
return $this->error(2005, '确认状态错误');
|
|
|
|
|
}
|
|
|
|
|
$confirmResult = $request->post('confirm_result', 1);
|
|
|
|
|
|
|
|
|
|
// 抖音预约信息z
|
|
|
|
|
$appoint = DyOrderProductAppointments::query()->where(['source_order_id' => $order['sn']])->order('id desc')->find();
|
2024-11-25 10:11:30 +08:00
|
|
|
|
if (empty($appoint)) {
|
|
|
|
|
return $this->error(2004, '该订单暂未预约,不可接单');
|
|
|
|
|
}
|
|
|
|
|
$dyOrderProduct = DyOrderProducts::query()->where(['dy_order_id' => $order['sn']])->find();
|
|
|
|
|
if (empty($dyOrderProduct)) {
|
|
|
|
|
return $this->error(2004, '订单商品未找到,不可接单');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$jnCategoryIds = [
|
|
|
|
|
"18004001", "18004003", "18004004", "18004005", "18004006", "18004007", "18004008", "18004009",
|
|
|
|
|
"18004010", "18003004", "4015004", "18003001", "18003002", "18003003", "18010001", "32001001",
|
|
|
|
|
"18002001", "18011001", "18011002", "18012001", "18012002", "18010001", "32001001", "32006002",
|
|
|
|
|
"32007001", "32007002", "32007003",
|
|
|
|
|
];
|
|
|
|
|
$zyxCategoryIds = ['32002001', '18010002', '32006001'];
|
|
|
|
|
|
|
|
|
|
$confirmData = [
|
|
|
|
|
'order_id' => $appoint->dy_order_id,
|
|
|
|
|
'source_order_id' => $appoint->source_order_id,
|
|
|
|
|
'confirm_info' => [
|
2024-12-02 18:43:20 +08:00
|
|
|
|
'confirm_result' => $confirmResult,
|
2024-11-25 10:11:30 +08:00
|
|
|
|
'reject_code' => $request->post('reject_code'), // 1: 库存已约满 2:商品需加价 3:无法满足顾客需求
|
|
|
|
|
// 'hotel_info' => [], // 境内住宿类目/酒景套餐 必填
|
|
|
|
|
// 'play_info' => [], // 境内游玩类目 必填
|
|
|
|
|
// 'free_travel_info' => $freeTravelInfo, // 自由行类目 必填
|
|
|
|
|
],
|
|
|
|
|
];
|
|
|
|
|
// 自由行必填参数
|
|
|
|
|
$dyApiService = new DyApiService();
|
2024-12-02 18:43:20 +08:00
|
|
|
|
if ($confirmResult == 1 && in_array($dyOrderProduct->category_id, $zyxCategoryIds)) {
|
2024-11-25 10:11:30 +08:00
|
|
|
|
$onedayTourList = [];
|
|
|
|
|
foreach ($dyOrderProduct->travel_details as $k => $travel_detail) {
|
|
|
|
|
array_push($onedayTourList, [
|
|
|
|
|
'sequence' => $k+1,
|
|
|
|
|
'hotel_info_list' => [],
|
|
|
|
|
'play_info_list' => []
|
|
|
|
|
]);
|
|
|
|
|
}
|
|
|
|
|
$confirmData['confirm_info']['free_travel_info']['oneday_tour_list'] = $onedayTourList;
|
|
|
|
|
}
|
2024-12-02 18:43:20 +08:00
|
|
|
|
if ($confirmResult == 1 && in_array($dyOrderProduct->category_id, $jnCategoryIds)) {
|
2024-11-25 10:11:30 +08:00
|
|
|
|
// 获取poi信息
|
|
|
|
|
$poiRes = $dyApiService->send(DyApiService::POI_QUERY, ['order_id' => $order->sn, 'account_id' => env('DY_ACCOUNT_ID')]);
|
|
|
|
|
$payInfo = [
|
|
|
|
|
'entrance_types' => [3],
|
|
|
|
|
'poi_info' => $poiRes['data']['poi_list'] ?? []
|
|
|
|
|
];
|
|
|
|
|
$showCerts = [];
|
|
|
|
|
if (isset($appoint['book_info'])) {
|
|
|
|
|
$bookInfo = json_decode(json_encode($appoint['book_info']), true);
|
|
|
|
|
foreach ($bookInfo['occupancies'] as $info) {
|
|
|
|
|
array_push($showCerts, [
|
|
|
|
|
'name' => $info['name'],
|
|
|
|
|
'card_no' => $info['license_id'] ?? '',
|
|
|
|
|
'cert_no' => $info['cert_no'] ?? '',
|
|
|
|
|
]);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$payInfo['show_certs'] = $showCerts;
|
|
|
|
|
$confirmData['confirm_info']['play_info'] = $payInfo;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$res = $dyApiService->send(DyApiService::ORDER_CONFIRM, $confirmData);
|
|
|
|
|
if ($res['flag'] == true) {
|
|
|
|
|
// 预约成功,更新预约状态
|
|
|
|
|
$order->appointment_status = 2;
|
|
|
|
|
$order->save();
|
|
|
|
|
|
|
|
|
|
return $this->success($res);
|
|
|
|
|
}
|
|
|
|
|
return $this->error(2005, $res['data']['description']);
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '出错了:' . $e->getMessage());
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-12-06 16:34:59 +08:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 抖音取消订单
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
*/
|
|
|
|
|
public function dyOrderCancel(Request $request) {
|
|
|
|
|
try {
|
|
|
|
|
$id = $request->post('id', 0);
|
|
|
|
|
$order = Orders::where('id', $id)->find();
|
|
|
|
|
if (empty($order)) {
|
|
|
|
|
return $this->error(2004, '记录没有找到.');
|
|
|
|
|
}
|
|
|
|
|
// 类型 1:取消预约并退款,2:取消预约
|
|
|
|
|
if (!$request->post('cancel_type') || !in_array($request->post('cancel_type'), [1, 2])) {
|
|
|
|
|
return $this->error(2005, '确认状态错误');
|
|
|
|
|
}
|
|
|
|
|
$cancelType = $request->post('cancel_type', 1);
|
|
|
|
|
|
|
|
|
|
$bookInfo = DyOrderProductAppointments::query()->where(['source_order_id' => $order->sn])->order('id desc')->find();
|
|
|
|
|
if (empty($bookInfo)) {
|
|
|
|
|
return $this->error(2006, '预约记录未找到');
|
|
|
|
|
}
|
|
|
|
|
$douyinService = new Douyin(5);
|
|
|
|
|
$res = $douyinService->bookCancelSmsSend($cancelType, $bookInfo->dy_order_id, $bookInfo->source_order_id);
|
|
|
|
|
Log::info('dyOrderCancel:' . json_encode($res));
|
|
|
|
|
if ($res->status_code == 0) {
|
|
|
|
|
return $this->success($res);
|
|
|
|
|
}
|
|
|
|
|
return $this->error(2005, $res->status_msg ?? '取消失败');
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '出错了:' . $e->getMessage());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 抖音售后订单
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
*/
|
|
|
|
|
public function dyAfterSaleOrder(Request $request) {
|
|
|
|
|
$orderId = $request->get('order_id');
|
|
|
|
|
$builder = OrderAfterSales::join('orders', 'order_after_sales.order_id = orders.sn', 'left');
|
|
|
|
|
$builder->whereIn('orders.order_status', [1, 2, 5]);
|
|
|
|
|
$builder->where('orders.is_direct_mode', '=', 1);
|
|
|
|
|
$builder->where('order_after_sales.status', '=', 0);
|
|
|
|
|
if (!empty($orderId)) {
|
|
|
|
|
$builder->where('orders.sn', $orderId);
|
|
|
|
|
}
|
|
|
|
|
if(!$request->admin->is_super) {
|
|
|
|
|
$builder->where('orders.admin_id','=', $request->admin->id);
|
|
|
|
|
} else {
|
|
|
|
|
$builder->where('orders.admin_id', '>', 0);
|
|
|
|
|
}
|
|
|
|
|
$builder->field(['order_after_sales.*']);
|
|
|
|
|
|
|
|
|
|
$list = $builder->paginate($request->get('limit',10));
|
|
|
|
|
return $this->success($list);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 抖音售后处理
|
|
|
|
|
* @param Request $request
|
|
|
|
|
* @return \support\Response
|
|
|
|
|
*/
|
|
|
|
|
public function dyAfterSaleOrderHandle(Request $request) {
|
|
|
|
|
try {
|
|
|
|
|
$id = $request->post('id', 0);
|
|
|
|
|
$order = OrderAfterSales::where('id', $id)->find();
|
|
|
|
|
if (empty($order)) {
|
|
|
|
|
return $this->error(2004, '记录没有找到.');
|
|
|
|
|
}
|
|
|
|
|
if (!in_array($request->post('audit_result'), [1, 2])) {
|
|
|
|
|
return $this->error(2004, '审核状态异常.');
|
|
|
|
|
}
|
|
|
|
|
$auditResult = $request->post('audit_result');
|
|
|
|
|
|
|
|
|
|
$douyinService = new Douyin(5);
|
|
|
|
|
// $auditOrderId, $auditResult, $bookId, $bookOrderId
|
|
|
|
|
$res = $douyinService->audit($order->audit_order_id, $auditResult, $order->book_id, $order->order_id);
|
|
|
|
|
if ($res->status_code == 0) {
|
|
|
|
|
OrderAfterSales::query()->where('order_id', $order->order_id)->update(['status' => $auditResult]);
|
|
|
|
|
return $this->success($res);
|
|
|
|
|
}
|
|
|
|
|
return $this->error(2005, $res->status_msg ?? '操作失败');
|
|
|
|
|
}catch(\Exception $e) {
|
|
|
|
|
return $this->error(2006, '出错了:' . $e->getMessage());
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-11-14 10:58:30 +08:00
|
|
|
|
}
|