You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
876 lines
29 KiB
876 lines
29 KiB
6 years ago
|
<?php
|
||
|
|
||
|
namespace frontend\controllers;
|
||
|
|
||
|
use common\libs\MyLib;
|
||
|
use common\models\AppointmentHistoryT;
|
||
|
use common\models\AppointmentT;
|
||
|
use common\models\CarCT;
|
||
|
use common\models\CarDT;
|
||
|
use common\models\CarET;
|
||
|
use common\models\CarT;
|
||
|
use common\models\MeetT;
|
||
|
use common\models\InvalidT;
|
||
|
use common\models\UserT;
|
||
|
use Yii;
|
||
|
use yii\data\Pagination;
|
||
|
use yii\db\Exception;
|
||
|
use yii\web\Response;
|
||
|
|
||
|
class TrackController extends BaseController
|
||
|
{
|
||
|
public function actionAdd()
|
||
|
{
|
||
|
$request = Yii::$app->request;
|
||
|
$car_id = $request->get('car_id',0);
|
||
|
|
||
|
return $this->renderPartial('add',[
|
||
|
'car_id' => $car_id
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
public function actionSave()
|
||
|
{
|
||
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
||
|
$request = Yii::$app->request;
|
||
|
$result = array();
|
||
|
$result['success'] = false;
|
||
|
$result['msg'] = '保存失败';
|
||
|
|
||
|
if($request->isPost) {
|
||
|
$car_id = $request->post('car_id',0);
|
||
|
$pdate = $request->post('pdate');
|
||
|
$ptime = $request->post('ptime');
|
||
|
$remark = $request->post('remark');
|
||
|
|
||
|
if($pdate == '') {
|
||
|
$result['msg'] = '请选择预约时间!';
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
$tran = AppointmentT::getDb()->beginTransaction();
|
||
|
try {
|
||
|
$row = AppointmentT::find()
|
||
|
->where('car_id='.$car_id)
|
||
|
->one();
|
||
|
if(empty($row)) {
|
||
|
$row = new AppointmentT();
|
||
|
}
|
||
|
|
||
|
$row->car_id = $car_id;
|
||
|
$row->user_id = $this->my->id;
|
||
|
$row->pdate = $pdate;
|
||
|
$row->ptime = $ptime;
|
||
|
$row->remark = $remark;
|
||
|
$row->is_first = 0;
|
||
|
$row->save();
|
||
|
|
||
|
$h_row = new AppointmentHistoryT();
|
||
|
$h_row->car_id = $car_id;
|
||
|
$h_row->user_id = $this->my->id;
|
||
|
$h_row->pdate = $pdate;
|
||
|
$h_row->ptime = $ptime;
|
||
|
$h_row->remark = $remark;
|
||
|
$h_row->save();
|
||
|
|
||
|
$this->addLog($car_id,'预约客户到'.$pdate.' '.$ptime.',预约内容为:'.$remark,1);
|
||
|
|
||
|
$tran->commit();
|
||
|
|
||
|
} catch(\Exception $e) {
|
||
|
$tran->rollBack();
|
||
|
throw $e;
|
||
|
}
|
||
|
|
||
|
$result['success'] = true;
|
||
|
$result['msg'] = '保存成功';
|
||
|
}
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
public function actionAjaxNext()
|
||
|
{
|
||
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
||
|
$session = Yii::$app->session;
|
||
|
$request = Yii::$app->request;
|
||
|
|
||
|
$index = $request->get('index');
|
||
|
$type = $request->get('type');
|
||
|
|
||
|
$sql = null;
|
||
|
if($type == 1) {
|
||
|
$sql = $session->get('track_first',array());
|
||
|
}
|
||
|
if($type == 2) {
|
||
|
$sql = $session->get('track_today',array());
|
||
|
}
|
||
|
if($type == 3) {
|
||
|
$sql = $session->get('track_all',array());
|
||
|
}
|
||
|
$car_id = 0;
|
||
|
$item = Yii::$app->db->createCommand($sql.' limit '.$index.',1')
|
||
|
->queryOne();
|
||
|
if($item) {
|
||
|
$car_id = $item['car_id'];
|
||
|
}
|
||
|
|
||
|
$result = array();
|
||
|
$result['success'] = true;
|
||
|
$result['car_id'] = $car_id;
|
||
|
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
//首拨
|
||
|
public function actionFirst()
|
||
|
{
|
||
|
$session = Yii::$app->session;
|
||
|
$request = Yii::$app->request;
|
||
|
$car_man = $request->get('car_man');
|
||
|
$phone = $request->get('phone');
|
||
|
$car_no = $request->get('car_no');
|
||
|
$page = $request->get('page',1);
|
||
|
$sort_key = $request->get('sort_key','appointment_t.pdate');
|
||
|
$sort_value = $request->get('sort_value','ASC');
|
||
|
$username = $request->get('username');
|
||
|
$type = $request->get('sort_type');
|
||
|
|
||
|
switch($type){
|
||
|
case 0:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
break;
|
||
|
case 1:
|
||
|
$sort_type = 'car_t.location=3';
|
||
|
break;
|
||
|
case 2:
|
||
|
$sort_type = 'car_t.location=6';
|
||
|
break;
|
||
|
default:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
}
|
||
|
$query = AppointmentT::find()
|
||
|
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
|
||
|
->where('appointment_t.is_first=1 and '.$sort_type)
|
||
|
->andWhere('appointment_t.pdate<="'.date('Y-m-d').'"');
|
||
|
|
||
|
$user_ids = $this->getChildrenUserIDs();
|
||
|
$query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
|
||
|
if($car_man != '') {
|
||
|
$query = $query->andWhere('car_t.car_man like "'.$car_man.'"');
|
||
|
}
|
||
|
if($phone != '') {
|
||
|
$query = $query->andWhere('car_t.phone="'.$phone.'"');
|
||
|
}
|
||
|
if($car_no != '') {
|
||
|
$query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
|
||
|
}
|
||
|
if($username != '') {
|
||
|
$user_info = UserT::find()
|
||
|
->where('username="'.$username.'"')
|
||
|
->one();
|
||
|
if($user_info)
|
||
|
$query = $query->andWhere('appointment_t.user_id='.$user_info->id);
|
||
|
}
|
||
|
if($sort_key != '') {
|
||
|
$query = $query->orderBy($sort_key.' '.$sort_value.', appointment_t.id '.$sort_value);
|
||
|
}
|
||
|
$sql = $query->createCommand()->rawSql;
|
||
|
// echo $query->createCommand()->rawSql;
|
||
|
$total = $query->count();
|
||
|
$session->remove('track_first');
|
||
|
$session->set('track_first',$sql);
|
||
|
|
||
|
$pagination = new Pagination(['totalCount' => $total,'pageSize'=>20]);
|
||
|
$pagination->setPage($page-1);
|
||
|
|
||
|
$query = $query->offset($pagination->offset)->limit($pagination->limit);
|
||
|
$items = $query->all();
|
||
|
|
||
|
$page_info = MyLib::getPageInfo($pagination);
|
||
|
$invalid_items = InvalidT::getTree();
|
||
|
|
||
|
return $this->render('first',[
|
||
|
'items' => $items,
|
||
|
'page_info' => $page_info,
|
||
|
'car_man' => $car_man,
|
||
|
'phone' => $phone,
|
||
|
'car_no' => $car_no,
|
||
|
'sort_type' => $type,
|
||
|
'page' => $page,
|
||
|
'sort_key' => $sort_key,
|
||
|
'sort_value' => $sort_value,
|
||
|
'type' => 1,
|
||
|
'username' => $username,
|
||
|
'invalid_items' => $invalid_items
|
||
|
]);
|
||
|
}
|
||
|
//针对从c库分配好的数据,经过c到e自动化而使数据而无法自动化
|
||
|
public function actionFirstOne()
|
||
|
{
|
||
|
$session = Yii::$app->session;
|
||
|
$request = Yii::$app->request;
|
||
|
$car_man = $request->get('car_man');
|
||
|
$phone = $request->get('phone');
|
||
|
$car_no = $request->get('car_no');
|
||
|
$page = $request->get('page',1);
|
||
|
$sort_key = $request->get('sort_key','appointment_t.pdate');
|
||
|
$sort_value = $request->get('sort_value','ASC');
|
||
|
$username = $request->get('username');
|
||
|
$type = $request->get('sort_type');
|
||
|
|
||
|
switch($type){
|
||
|
case 0:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
break;
|
||
|
case 1:
|
||
|
$sort_type = 'car_t.location=3';
|
||
|
break;
|
||
|
case 2:
|
||
|
$sort_type = 'car_t.location=6';
|
||
|
break;
|
||
|
default:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
}
|
||
|
$query = AppointmentT::find()
|
||
|
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
|
||
|
->where('appointment_t.is_first=1 and '.$sort_type)
|
||
|
->andWhere('appointment_t.pdate<="'.date('Y-m-d').'"');
|
||
|
|
||
|
$user_ids = $this->getChildrenUserIDs();
|
||
|
$query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
|
||
|
if($car_man != '') {
|
||
|
$query = $query->andWhere('car_t.car_man like "'.$car_man.'"');
|
||
|
}
|
||
|
if($phone != '') {
|
||
|
$query = $query->andWhere('car_t.phone="'.$phone.'"');
|
||
|
}
|
||
|
if($car_no != '') {
|
||
|
$query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
|
||
|
}
|
||
|
if($username != '') {
|
||
|
$user_info = UserT::find()
|
||
|
->where('username="'.$username.'"')
|
||
|
->one();
|
||
|
if($user_info)
|
||
|
$query = $query->andWhere('appointment_t.user_id='.$user_info->id);
|
||
|
}
|
||
|
if($sort_key != '') {
|
||
|
$query = $query->orderBy($sort_key.' '.$sort_value.', appointment_t.id '.$sort_value);
|
||
|
}
|
||
|
$sql = $query->createCommand()->rawSql;
|
||
|
// echo $query->createCommand()->rawSql;
|
||
|
$total = $query->count();
|
||
|
$session->remove('track_first');
|
||
|
$session->set('track_first',$sql);
|
||
|
|
||
|
$pagination = new Pagination(['totalCount' => $total,'pageSize'=>20]);
|
||
|
$pagination->setPage($page-1);
|
||
|
|
||
|
$query = $query->offset($pagination->offset)->limit($pagination->limit);
|
||
|
$items = $query->all();
|
||
|
|
||
|
foreach($items as $vs){
|
||
|
// dd($vs);
|
||
|
$carE_info= CarET::findOne(['id'=>$vs->car_id]);
|
||
|
$carE_info->user_id=$vs->user_id;
|
||
|
$carE_info->save();
|
||
|
$this->addLog($vs->car_id,'修改跟踪操作员',1);
|
||
|
// dd($carE_info);
|
||
|
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
$page_info = MyLib::getPageInfo($pagination);
|
||
|
$invalid_items = InvalidT::getTree();
|
||
|
|
||
|
return $this->render('first',[
|
||
|
'items' => $items,
|
||
|
'page_info' => $page_info,
|
||
|
'car_man' => $car_man,
|
||
|
'phone' => $phone,
|
||
|
'car_no' => $car_no,
|
||
|
'sort_type' => $type,
|
||
|
'page' => $page,
|
||
|
'sort_key' => $sort_key,
|
||
|
'sort_value' => $sort_value,
|
||
|
'type' => 1,
|
||
|
'username' => $username,
|
||
|
'invalid_items' => $invalid_items
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
//今日预约
|
||
|
public function actionToday()
|
||
|
{
|
||
|
$session = Yii::$app->session;
|
||
|
$request = Yii::$app->request;
|
||
|
$car_man = $request->get('car_man');
|
||
|
$phone = $request->get('phone');
|
||
|
$car_no = $request->get('car_no');
|
||
|
$page = $request->get('page',1);
|
||
|
$sort_key = $request->get('sort_key','appointment_t.pdate');
|
||
|
$sort_value = $request->get('sort_value','ASC');
|
||
|
$username = $request->get('username');
|
||
|
|
||
|
$user_id = $request->get('user_id');
|
||
|
$ptype = $request->get('ptype');
|
||
|
$type = $request->get('sort_type');
|
||
|
$date_begin = $request->get('date_begin');
|
||
|
$date_end = $request->get('date_end');
|
||
|
|
||
|
switch($type){
|
||
|
case 0:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
break;
|
||
|
case 1:
|
||
|
$sort_type = 'car_t.location=3';
|
||
|
break;
|
||
|
case 2:
|
||
|
$sort_type = 'car_t.location=6';
|
||
|
break;
|
||
|
default:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
}
|
||
|
|
||
|
$query = AppointmentT::find()
|
||
|
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
|
||
|
->where('appointment_t.is_first=0 and '.$sort_type)
|
||
|
->andWhere('appointment_t.pdate<="'.date('Y-m-d').'"');
|
||
|
|
||
|
// $user_ids = $this->getChildrenUserIDs();
|
||
|
// $query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
if($username == '') {
|
||
|
$user_ids = $this->getChildrenUserIDs();
|
||
|
$query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
}
|
||
|
|
||
|
if($car_man != '') {
|
||
|
$query = $query->andWhere('car_t.car_man like "'.$car_man.'"');
|
||
|
}
|
||
|
if($phone != '') {
|
||
|
$query = $query->andWhere('car_t.phone="'.$phone.'"');
|
||
|
}
|
||
|
if($ptype > 0) {
|
||
|
$query = $query->andWhere('appointment_t.ptype='.$ptype);
|
||
|
}
|
||
|
if($car_no != '') {
|
||
|
$query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
|
||
|
}
|
||
|
if($sort_key != '') {
|
||
|
$query = $query->orderBy($sort_key.' '.$sort_value.', appointment_t.id '.$sort_value);
|
||
|
}
|
||
|
if($date_begin != '') {
|
||
|
$query = $query->andWhere('appointment_t.pdate>="'.$date_begin.'"');
|
||
|
}
|
||
|
if($date_end != '') {
|
||
|
$query = $query->andWhere('appointment_t.pdate<="'.$date_end.'"');
|
||
|
}
|
||
|
// if($username == '') {
|
||
|
// $user_ids = $this->getChildrenUserIDs();
|
||
|
// $query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
// }
|
||
|
if($username != '') {
|
||
|
$user_query = UserT::find()
|
||
|
->where('username="'.$username.'"')
|
||
|
->all();
|
||
|
foreach($user_query as $user_info) {
|
||
|
$user_ids[] = $user_info->id;
|
||
|
}
|
||
|
if(count($user_ids) > 0)
|
||
|
$query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
}
|
||
|
$sql = $query->createCommand()->rawSql;
|
||
|
// echo $query->createCommand()->rawSql;
|
||
|
$total = $query->count();
|
||
|
$session->remove('track_today');
|
||
|
$session->set('track_today',$sql);
|
||
|
|
||
|
$pagination = new Pagination(['totalCount' => $total,'pageSize'=>20]);
|
||
|
$pagination->setPage($page-1);
|
||
|
|
||
|
$query = $query->offset($pagination->offset)->limit($pagination->limit);
|
||
|
$items = $query->all();
|
||
|
|
||
|
$page_info = MyLib::getPageInfo($pagination);
|
||
|
|
||
|
$list = MeetT::getAllData(2);
|
||
|
$user_items = $this->my->getChildren();
|
||
|
return $this->render('today',[
|
||
|
'items' => $items,
|
||
|
'page_info' => $page_info,
|
||
|
'car_man' => $car_man,
|
||
|
'phone' => $phone,
|
||
|
'ptype' => $ptype,
|
||
|
'list' => $list,
|
||
|
'sort_type' => $type,
|
||
|
'car_no' => $car_no,
|
||
|
'page' => $page,
|
||
|
'sort_key' => $sort_key,
|
||
|
'sort_value' => $sort_value,
|
||
|
'type' => 2,
|
||
|
'user_id' => $user_id,
|
||
|
'user_items' => $user_items,
|
||
|
'username' => $username,
|
||
|
'date_begin' => $date_begin,
|
||
|
'date_end' => $date_end
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
//全部预约
|
||
|
public function actionAll()
|
||
|
{
|
||
|
$session = Yii::$app->session;
|
||
|
$request = Yii::$app->request;
|
||
|
$car_man = $request->get('car_man');
|
||
|
$phone = $request->get('phone');
|
||
|
$car_no = $request->get('car_no');
|
||
|
$page = $request->get('page',1);
|
||
|
$sort_key = $request->get('sort_key','appointment_t.pdate');
|
||
|
$sort_value = $request->get('sort_value','ASC');
|
||
|
$username = $request->get('username');
|
||
|
$date_begin = $request->get('date_begin');
|
||
|
$date_end = $request->get('date_end');
|
||
|
$ptype = $request->get('ptype');
|
||
|
$type = $request->get('sort_type');
|
||
|
$user_id = $request->get('user_id');
|
||
|
|
||
|
switch($type){
|
||
|
case 0:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
break;
|
||
|
case 1:
|
||
|
$sort_type = 'car_t.location=3';
|
||
|
break;
|
||
|
case 2:
|
||
|
$sort_type = 'car_t.location=6';
|
||
|
break;
|
||
|
default:
|
||
|
$sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
}
|
||
|
|
||
|
$query = AppointmentT::find()
|
||
|
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
|
||
|
->where('appointment_t.is_first=0 and '.$sort_type);
|
||
|
|
||
|
$user_ids = $this->getChildrenUserIDs();
|
||
|
$query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
|
||
|
if($car_man != '') {
|
||
|
$query = $query->andWhere('car_t.car_man like "'.$car_man.'"');
|
||
|
}
|
||
|
if($phone != '') {
|
||
|
$query = $query->andWhere('car_t.phone="'.$phone.'"');
|
||
|
}
|
||
|
if($ptype > 0) {
|
||
|
$query = $query->andWhere('appointment_t.ptype='.$ptype);
|
||
|
}
|
||
|
if($car_no != '') {
|
||
|
$query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
|
||
|
}
|
||
|
if($sort_key != '') {
|
||
|
$query = $query->orderBy($sort_key.' '.$sort_value.', appointment_t.id '.$sort_value);
|
||
|
}
|
||
|
if($date_begin != '') {
|
||
|
$query = $query->andWhere('insurer1_date>="'.$date_begin.'"');
|
||
|
}
|
||
|
if($date_end != '') {
|
||
|
$query = $query->andWhere('insurer1_date<="'.$date_end.'"');
|
||
|
}
|
||
|
if($username != '') {
|
||
|
$user_info = UserT::find()
|
||
|
->where('username="'.$username.'"')
|
||
|
->one();
|
||
|
if($user_info)
|
||
|
$query = $query->andWhere('appointment_t.user_id='.$user_info->id);
|
||
|
}
|
||
|
$sql = $query->createCommand()->rawSql;
|
||
|
// echo $query->createCommand()->rawSql;
|
||
|
$total = $query->count();
|
||
|
$session->remove('track_all');
|
||
|
$session->set('track_all',$sql);
|
||
|
|
||
|
$pagination = new Pagination(['totalCount' => $total,'pageSize'=>20]);
|
||
|
$pagination->setPage($page-1);
|
||
|
|
||
|
$query = $query->offset($pagination->offset)->limit($pagination->limit);
|
||
|
$items = $query->all();
|
||
|
|
||
|
$page_info = MyLib::getPageInfo($pagination);
|
||
|
$invalid_items = InvalidT::getTree();
|
||
|
|
||
|
$list = MeetT::getAllData(2);
|
||
|
$user_items = $this->my->getChildren();
|
||
|
|
||
|
return $this->render('all',[
|
||
|
'items' => $items,
|
||
|
'page_info' => $page_info,
|
||
|
'car_man' => $car_man,
|
||
|
'phone' => $phone,
|
||
|
'ptype' => $ptype,
|
||
|
'sort_type' => $type,
|
||
|
'list' => $list,
|
||
|
'car_no' => $car_no,
|
||
|
'page' => $page,
|
||
|
'sort_key' => $sort_key,
|
||
|
'sort_value' => $sort_value,
|
||
|
'type' => 3,
|
||
|
'username' => $username,
|
||
|
'user_items' => $user_items,
|
||
|
'user_id' => $user_id,
|
||
|
'invalid_items' => $invalid_items,
|
||
|
'date_begin' => $date_begin,
|
||
|
'date_end' => $date_end,
|
||
|
]);
|
||
|
}
|
||
|
//领近保险快到期90天
|
||
|
public function actionEndAll()
|
||
|
{
|
||
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
||
|
$request = Yii::$app->request;
|
||
|
$result = array();
|
||
|
$result['success'] = false;
|
||
|
$result['msg'] = '读取失败';
|
||
|
$query = AppointmentT::find()
|
||
|
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
|
||
|
->where('appointment_t.is_first=0 and car_t.location=6');
|
||
|
$user_ids = $this->getChildrenUserIDs();
|
||
|
$query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
$bgstr= date("Y-m-d",strtotime("+90 day"));
|
||
|
|
||
|
//结束时间
|
||
|
$endstr=date("Y-m-d",strtotime("+97 day"));
|
||
|
$query = $query->andWhere('insurer1_date>"'.$bgstr.'"');
|
||
|
|
||
|
$query = $query->andWhere('insurer1_date<="'.$endstr.'"');
|
||
|
$data=$query->count();
|
||
|
if($data>=1){
|
||
|
$result['success'] = true;
|
||
|
$result['num'] = $data;
|
||
|
$result['msg'] = '读取成功';
|
||
|
}else{
|
||
|
$result['msg'] = '没有数据';
|
||
|
}
|
||
|
// var_dump($data);
|
||
|
// die;
|
||
|
return $result;
|
||
|
}
|
||
|
public function actionEndAllList()
|
||
|
{
|
||
|
|
||
|
$session = Yii::$app->session;
|
||
|
$request = Yii::$app->request;
|
||
|
// $car_man = $request->get('car_man');
|
||
|
// $phone = $request->get('phone');
|
||
|
// $car_no = $request->get('car_no');
|
||
|
$page = $request->get('page',1);
|
||
|
$day = $request->get('day',1);
|
||
|
// $sort_key = $request->get('sort_key','appointment_t.pdate');
|
||
|
// $sort_value = $request->get('sort_value','ASC');
|
||
|
// $username = $request->get('username');
|
||
|
// $date_begin = $request->get('date_begin');
|
||
|
// $date_end = $request->get('date_end');
|
||
|
// $ptype = $request->get('ptype');
|
||
|
// $type = $request->get('sort_type');
|
||
|
// $user_id = $request->get('user_id');
|
||
|
|
||
|
// switch($type){
|
||
|
// case 0:
|
||
|
// $sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
// break;
|
||
|
// case 1:
|
||
|
// $sort_type = 'car_t.location=3';
|
||
|
// break;
|
||
|
// case 2:
|
||
|
// $sort_type = 'car_t.location=6';
|
||
|
// break;
|
||
|
// default:
|
||
|
// $sort_type = '(car_t.location=3 or car_t.location=6)';
|
||
|
// }
|
||
|
|
||
|
$query = AppointmentT::find()
|
||
|
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
|
||
|
->where('appointment_t.is_first=0 and car_t.location=6');
|
||
|
|
||
|
$user_ids = $this->getChildrenUserIDs();
|
||
|
$query = $query->andWhere(['in','appointment_t.user_id',$user_ids]);
|
||
|
|
||
|
// if($car_man != '') {
|
||
|
// $query = $query->andWhere('car_t.car_man like "'.$car_man.'"');
|
||
|
// }
|
||
|
// if($phone != '') {
|
||
|
// $query = $query->andWhere('car_t.phone="'.$phone.'"');
|
||
|
// }
|
||
|
// if($ptype > 0) {
|
||
|
// $query = $query->andWhere('appointment_t.ptype='.$ptype);
|
||
|
// }
|
||
|
// if($car_no != '') {
|
||
|
// $query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
|
||
|
// }
|
||
|
// if($sort_key != '') {
|
||
|
// $query = $query->orderBy($sort_key.' '.$sort_value.', appointment_t.id '.$sort_value);
|
||
|
// }
|
||
|
$bgstr= date("Y-m-d",strtotime("+90 day"));
|
||
|
|
||
|
//结束时间
|
||
|
$endstr=date("Y-m-d",strtotime("+97 day"));
|
||
|
$query = $query->andWhere('insurer1_date>"'.$bgstr.'"');
|
||
|
|
||
|
$query = $query->andWhere('insurer1_date<="'.$endstr.'"');
|
||
|
|
||
|
|
||
|
|
||
|
// if($username != '') {
|
||
|
// $user_info = UserT::find()
|
||
|
// ->where('username="'.$username.'"')
|
||
|
// ->one();
|
||
|
// if($user_info)
|
||
|
// $query = $query->andWhere('appointment_t.user_id='.$user_info->id);
|
||
|
// }
|
||
|
$sql = $query->createCommand()->rawSql;
|
||
|
// echo $query->createCommand()->rawSql;
|
||
|
$total = $query->count();
|
||
|
$session->remove('track_all');
|
||
|
$session->set('track_all',$sql);
|
||
|
|
||
|
$pagination = new Pagination(['totalCount' => $total,'pageSize'=>20]);
|
||
|
$pagination->setPage($page-1);
|
||
|
|
||
|
$query = $query->offset($pagination->offset)->limit($pagination->limit);
|
||
|
$items = $query->all();
|
||
|
|
||
|
$page_info = MyLib::getPageInfo($pagination);
|
||
|
|
||
|
|
||
|
$list = MeetT::getAllData(2);
|
||
|
$user_items = $this->my->getChildren();
|
||
|
|
||
|
if($day==1){
|
||
|
$days=2;
|
||
|
}else{
|
||
|
$days=3;
|
||
|
}
|
||
|
|
||
|
return $this->render('all-list',[
|
||
|
'items' => $items,
|
||
|
'page_info' => $page_info,
|
||
|
|
||
|
'list' => $list,
|
||
|
|
||
|
'page' => $page,
|
||
|
|
||
|
'type' => $days,
|
||
|
|
||
|
'user_items' => $user_items,
|
||
|
|
||
|
|
||
|
|
||
|
]);
|
||
|
}
|
||
|
public function actionInvalidC()
|
||
|
{
|
||
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
||
|
$request = Yii::$app->request;
|
||
|
$result = array();
|
||
|
$result['success'] = false;
|
||
|
$result['msg'] = '操作失败';
|
||
|
|
||
|
if($request->isPost) {
|
||
|
$ids = $request->post('ids',array());
|
||
|
if(count($ids) == 0) {
|
||
|
$result['msg'] = '请先钩选车辆';
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
$tran = CarT::getDb()->beginTransaction();
|
||
|
try {
|
||
|
foreach($ids as $id) {
|
||
|
$car_info = CarT::findOne(['id'=>$id]);
|
||
|
$car_info->location = 3;
|
||
|
$car_info->save();
|
||
|
|
||
|
$c_info = CarCT::findOne(['id'=>$id]);
|
||
|
$c_info->user_id = 0;
|
||
|
$c_info->save();
|
||
|
|
||
|
//删除预约
|
||
|
AppointmentT::deleteAll('car_id='.$car_info->id);
|
||
|
|
||
|
//删除保单
|
||
|
OrderT::deleteAll('car_id='.$car_info->id.' and status_id<2');
|
||
|
|
||
|
$this->addLog($car_info->id,'回收车辆数据到C库',1);
|
||
|
}
|
||
|
$result['success'] = true;
|
||
|
$result['msg'] = '操作成功';
|
||
|
|
||
|
$tran->commit();
|
||
|
} catch (\Exception $e) {
|
||
|
$tran->rollBack();
|
||
|
echo $e->getMessage();
|
||
|
}
|
||
|
}
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
public function actionCarCancel()
|
||
|
{
|
||
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
||
|
$request = Yii::$app->request;
|
||
|
$result = array();
|
||
|
$result['success'] = false;
|
||
|
$result['msg'] = '放弃失败';
|
||
|
|
||
|
if($request->isPost) {
|
||
|
$id = $request->post('id',0);
|
||
|
|
||
|
if($id > 0) {
|
||
|
$tran = CarCT::getDb()->beginTransaction();
|
||
|
try {
|
||
|
$c_info = CarCT::findOne(['id'=>$id]);
|
||
|
if($c_info->user_id > 0)
|
||
|
$this->addLog($c_info->id,'业务员:'.$c_info->user->getShowName().'自动放弃跟踪数据',1);
|
||
|
|
||
|
//删除预约
|
||
|
AppointmentT::deleteAll('user_id='.$c_info->user_id.' and car_id='.$c_info->id);
|
||
|
|
||
|
$car_info = $c_info->car;
|
||
|
$car_info->user_id = 0;
|
||
|
$car_info->location = 4;
|
||
|
$car_info->save();
|
||
|
|
||
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
||
|
|
||
|
$d_info = CarDT::findOne(['id'=>$car_info->id]);
|
||
|
if(!$d_info) {
|
||
|
$d_info = new CarDT();
|
||
|
$d_info->id = $car_info->id;
|
||
|
$d_info->user_id = 0;
|
||
|
$d_info->save();
|
||
|
|
||
|
$this->addLog($car_info->id,'从C库分配到D库',1);
|
||
|
}
|
||
|
|
||
|
$tran->commit();
|
||
|
} catch(\Exception $e) {
|
||
|
$tran->rollBack();
|
||
|
throw $e;
|
||
|
}
|
||
|
|
||
|
$result['success'] = true;
|
||
|
$result['msg'] = '放弃成功';
|
||
|
}
|
||
|
}
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
//从e库放弃到a库
|
||
|
// public function actionCarCancelE()
|
||
|
// {
|
||
|
// Yii::$app->response->format = Response::FORMAT_JSON;
|
||
|
// $request = Yii::$app->request;
|
||
|
// $result = array();
|
||
|
// $result['success'] = false;
|
||
|
// $result['msg'] = '放弃失败';
|
||
|
//
|
||
|
// if($request->isPost) {
|
||
|
// $id = $request->post('id',0);
|
||
|
//
|
||
|
// if($id > 0) {
|
||
|
// $tran = CarET::getDb()->beginTransaction();
|
||
|
// try {
|
||
|
// $c_info = CarET::findOne(['id'=>$id]);
|
||
|
// if($c_info->user_id > 0)
|
||
|
// $this->addLog($c_info->id,'业务员:'.$c_info->user->getShowName().'自动放弃跟踪数据',1);
|
||
|
//
|
||
|
// //删除预约
|
||
|
// AppointmentT::deleteAll('user_id='.$c_info->user_id.' and car_id='.$c_info->id);
|
||
|
//
|
||
|
// $car_info = $c_info->car;
|
||
|
// $car_info->user_id = 0;
|
||
|
// $car_info->location = 1;
|
||
|
// $car_info->save();
|
||
|
//
|
||
|
// CarET::deleteAll(['id'=>$car_info->id]);
|
||
|
//
|
||
|
// $this->addLog($car_info->id,'从E库分配到A库',1);
|
||
|
//
|
||
|
// $tran->commit();
|
||
|
// } catch(\Exception $e) {
|
||
|
// $tran->rollBack();
|
||
|
// throw $e;
|
||
|
// }
|
||
|
//
|
||
|
// $result['success'] = true;
|
||
|
// $result['msg'] = '放弃成功';
|
||
|
// }
|
||
|
// }
|
||
|
// return $result;
|
||
|
// }
|
||
|
|
||
|
/**
|
||
|
* E库数据放弃到D库
|
||
|
* xzz
|
||
|
* 2017-12-21
|
||
|
*/
|
||
|
public function actionCarCancelE()
|
||
|
{
|
||
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
||
|
$request = Yii::$app->request;
|
||
|
|
||
|
$result = [
|
||
|
'success' => false,
|
||
|
'msg' => '放弃失败'
|
||
|
];
|
||
|
|
||
|
if($request->isPost){
|
||
|
$id = $request->post('id', 0);
|
||
|
|
||
|
if($id > 0){
|
||
|
$tran = CarET::getDb()->beginTransaction();
|
||
|
|
||
|
try{
|
||
|
$c_info = CarET::findOne(['id' => $id]);
|
||
|
|
||
|
if($c_info->user_id > 0)
|
||
|
$this->addLog($c_info->id,'业务员:'.$c_info->user->getShowName().'自动放弃跟踪数据',1);
|
||
|
|
||
|
//删除预约
|
||
|
AppointmentT::deleteAll('user_id = '.$c_info->user_id.' and car_id = '.$c_info->id);
|
||
|
|
||
|
$car_info = $c_info->car;
|
||
|
$car_info->user_id = 0;
|
||
|
$car_info->location = 4;
|
||
|
$car_info->save();
|
||
|
|
||
|
CarET::deleteAll(['id' => $car_info->id]);
|
||
|
|
||
|
$d_info = CarDT::findOne(['id' => $car_info->id]);
|
||
|
if(!$d_info){
|
||
|
$d_info = new CarDT();
|
||
|
$d_info->id = $car_info->id;
|
||
|
$d_info->user_id = 0;
|
||
|
$d_info->save();
|
||
|
|
||
|
$this->addLog($car_info->id,'从E库分配到D库',1);
|
||
|
}
|
||
|
|
||
|
$tran->commit();
|
||
|
}catch (Exception $e){
|
||
|
$tran->rollBack();
|
||
|
throw $e;
|
||
|
}
|
||
|
|
||
|
$result = [
|
||
|
'success' => true,
|
||
|
'msg' => '放弃成功'
|
||
|
];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return $result;
|
||
|
}
|
||
|
}
|