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.
simple-yewu/frontend/controllers/FiltrationtController.php

1315 lines
47 KiB

6 years ago
<?php
namespace frontend\controllers;
use common\libs\MyLib;
use common\models\AppointmentHistoryT;
use common\models\AppointmentT;
use common\models\FiltrationT;
use common\models\CarBT;
use common\models\CarCT;
use common\models\MeetT;
use common\models\CarDT;
use common\models\CarET;
use common\models\CarInvalidT;
use common\models\CarMistakeT;
use common\models\CarT;
use common\models\CleanT;
use common\models\CleanTongji;
use common\models\InvalidT;
use common\models\OrderT;
use common\models\UserT;
use Yii;
use yii\data\Pagination;
use yii\web\Response;
class FiltrationtController extends BaseController
{
public function actionIndex()
{
$request = Yii::$app->request;
$car_id = $request->get('car_id');
$page = $request->get('page',1);
$query = AppointmentHistoryT::find()
->where(['car_id'=>$car_id])
->orderBy('id DESC');
$total = $query->count();
$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);
return $this->render('index',[
'car_id' => $car_id,
'items' => $items,
'page' => $page,
'page_info' => $page_info
]);
}
public function actionAjaxIndex()
{
Yii::$app->response->format = Response::FORMAT_JSON;
$request = Yii::$app->request;
$car_id = $request->get('car_id');
$page = $request->get('page',1);
$result = array();
$result['success'] = false;
$result['msg'] = '读取失败';
$pdate = date("Y-m-d",strtotime("-6 months"));
$query = FiltrationT::find()
->where(['car_id'=>$car_id])
->andWhere('pdate>"'.$pdate.'"')
->orderBy('pdate DESC,id DESC');
//echo $query->createCommand()->rawSql;
$total = $query->count();
$pagination = new Pagination(['totalCount' => $total,'pageSize'=>20]);
$pagination->setPage($page-1);
$query = $query->offset($pagination->offset)->limit($pagination->limit);
$items = $query->all();
// dd($items);
$page_info = MyLib::getAjaxPageInfo($pagination,'appointment_list');
$html = $this->renderPartial('ajax-index',[
'car_id' => $car_id,
'items' => $items,
'page' => $page,
'page_info' => $page_info
]);
$result['success'] = true;
$result['html'] = $html;
return $result;
}
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');
$ptype = $request->post('ptype');
$business_group_id = $request->post('business_group_id', 0);
if($pdate == '') {
$result['msg'] = '请选择预约时间!';
return $result;
}
if($ptype == '0') {
$result['msg'] = '请选择预约类型!';
return $result;
}
$tran = AppointmentT::getDb()->beginTransaction();
try {
$car_user_info = null;
$car_info = CarT::findOne(['id'=>$car_id]);
switch($car_info->location) {
case 2:
$car_user_info = CarBT::findOne(['id'=>$car_id]);
break;
case 3:
$car_user_info = CarCT::findOne(['id'=>$car_id]);
break;
case 4:
$car_user_info = CarDT::findOne(['id'=>$car_id]);
break;
case 5:
$car_user_info = CarInvalidT::findOne(['id'=>$car_id]);
break;
case 6:
$car_user_info = CarET::findOne(['id'=>$car_id]);
break;
case 14:
$car_user_info = CleanT::findOne(['id'=>$car_id]);
break;
default:
$name = '';
}
if(!$car_user_info) {
$result['msg'] = '该车辆未分配';
return $result;
}
if($car_user_info->user_id != $this->my->id) {
$result['msg'] = '该车辆未分配给'.$this->my->username.', 无法预约';
return $result;
}
$clean_info=CleanT::findOne(['id'=>$car_id]);
if($clean_info){
$clean_info->yuyue=2;
$clean_info->lingqu_status=2;
$clean_info->save();
}
$cleantj_info=CleanTongji::find()->where(['car_id'=>$car_id])->one();
if(!$cleantj_info){
$cleantj_info=new CleanTongji();
$cleantj_info->user_id=$this->my->id;
$cleantj_info->yuyue_num=1;
$cleantj_info->yuefen=date('Y-m-d');
$cleantj_info->car_id=$car_id;
$cleantj_info->car_no=$car_info->car_no;
$cleantj_info->save();
$this->addLog($car_info->id, '预约成功', 1);
}
$row = FiltrationT::find()
->where('car_id='.$car_id)
->one();
if(empty($row)) {
$row = new FiltrationT();
$row->user_id = $this->my->id;
}
$old_user_id = 0;
if($row->user_id != $this->my->id)
$old_user_id = $row->user_id;
$row->car_id = $car_id;
$row->user_id = $this->my->id;
$row->pdate = $pdate;
$row->ptime = $ptime;
$row->ptype = $ptype;
$row->remark = $remark;
$row->business_group_id = $business_group_id;
$row->is_first = 0;
$row->save();
$log_txt = '';
if($old_user_id > 0) {
$log_txt = '旧业务员是:'.$old_user_id.' ';
}
$this->addLog($car_id,$log_txt.'预约客户到'.$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('appointment_first',array());
}
if($type == 2) {
$sql = $session->get('appointment_today',array());
}
if($type == 3) {
$sql = $session->get('appointment_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);
$username = $request->get('username');
$sort_key = $request->get('sort_key','filtration_t.pdate');
$sort_value = $request->get('sort_value','ASC');
$user_id = $request->get('user_id');
$register_begin = $request->get('register_begin');
$register_end = $request->get('register_end');
$insurer1_begin = $request->get('insurer1_begin');
$insurer1_end = $request->get('insurer1_end');
$insurer1_month = $request->get('insurer1_month');
$insurer1_day = $request->get('insurer1_day');
$insurer1_month1 = $request->get('insurer1_month1');
$insurer1_day1 = $request->get('insurer1_day1');
$query = FiltrationT::find()
->leftJoin('car_t','`car_t`.`id`=`filtration_t`.`car_id`')
->andWhere(['!=','`filtration_t`.`remark`','首次分配'])
->andWhere('delete_status=1');
if($username == '') {
// $user_ids = $this->getChildrenUserIDs();
// $query = $query->andWhere(['in','filtration_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 like "'.$phone.'"');
}
if($car_no != '') {
$query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
}
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','filtration_t.user_id',$user_ids]);
}
if($sort_key != '') {
$query = $query->orderBy($sort_key.' '.$sort_value.',filtration_t.id '.$sort_value);
}
if($register_begin != '') {
$query = $query->andWhere('register_date>="'.$register_begin.'"');
}
if($register_end != '') {
$query = $query->andWhere('register_date<="'.$register_end.'"');
}
// if($insurer1_begin != '') {
// $query = $query->andWhere('car_t.insurer2_date>="'.$insurer1_begin.'"');
// }
// if($insurer1_end != '') {
// $query = $query->andWhere('car_t.insurer2_date<="'.$insurer1_end.'"');
// }
if($insurer1_month != '') {
$query = $query->andWhere('month(car_t.insurer1_date)>="'.$insurer1_month.'"');
}
if($insurer1_day != '') {
$query = $query->andWhere('day(car_t.insurer1_date)>="'.$insurer1_day.'"');
}
if($insurer1_month1 != '') {
$query = $query->andWhere('month(car_t.insurer1_date)<="'.$insurer1_month1.'"');
}
if($insurer1_day1 != '') {
$query = $query->andWhere('day(car_t.insurer1_date)<="'.$insurer1_day1.'"');
}
$sql = $query->createCommand()->rawSql;
// echo $query->createCommand()->rawSql;
$total = $query->count();
$pagination = new Pagination(['totalCount' => $total,'pageSize'=>20]);
$pagination->setPage($page-1);
$current_index = $pagination->offset;
$query = $query->offset($pagination->offset)->limit($pagination->limit);
$items = $query->all();
$page_info = MyLib::getPageInfo($pagination);
$invalid_items = InvalidT::getTree();
$user_items = $this->my->getChildren();
return $this->render('first',[
'items' => $items,
'page_info' => $page_info,
'car_man' => $car_man,
'phone' => $phone,
'car_no' => $car_no,
'page' => $page,
'sort_key' => $sort_key,
'sort_value' => $sort_value,
'type' => 1,
'invalid_items' => $invalid_items,
'username' => $username,
'user_items' => $user_items,
'user_id' => $user_id,
'register_begin' => $register_begin,
'register_end' => $register_end,
'insurer1_begin' => $insurer1_begin,
'insurer1_end' => $insurer1_end,
'insurer1_month' =>$insurer1_month,
'insurer1_day' =>$insurer1_day,
'insurer1_month1' =>$insurer1_month1,
'insurer1_day1' =>$insurer1_day1,
]);
}
public function actionInfo()
{
$request = Yii::$app->request;
$id = $request->get('id',0);
$type = $request->get('type',0);
$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');
$next_index = $request->get('next_index',0);
$back_params = $request->get('back_params');
$my_path = $this->my->group?$this->my->group->getPath():'';
$car_info = CarT::findOne(['id'=>$id]);
$success_items = InvalidT::getTree(1);
// $failure_items = InvalidT::getTreeXinbaoNew(2);
$failure_items = InvalidT::getTreeClean(2);
//下一辆
$next_id = 0;
if($type == 1) {
$query = AppointmentT::find()
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
->where('appointment_t.is_first=1 and car_t.is_track=0')
->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($sort_key != '') {
$query = $query->orderBy($sort_key.' '.$sort_value);
}
$next_item = $query->offset($next_index)->one();
if($next_item) {
$next_id = $next_item->car_id;
}
$next_index++;
}
if($type == 2) {
$query = AppointmentT::find()
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
->where('appointment_t.is_first=0 and car_t.is_track=0')
->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($sort_key != '') {
$query = $query->orderBy($sort_key.' '.$sort_value);
}
$next_item = $query->offset($next_index)->one();
if($next_item) {
$next_id = $next_item->car_id;
}
$next_index++;
}
if($type == 3) {
$query = AppointmentT::find()
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
->where('appointment_t.is_first=0 and car_t.is_track=0');
$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($sort_key != '') {
$query = $query->orderBy($sort_key.' '.$sort_value);
}
$next_item = $query->offset($next_index)->one();
if($next_item) {
$next_id = $next_item->car_id;
}
$next_index++;
}
//获取礼品数据
$list = MeetT::getAllData(1);
return $this->render('info',[
'type' => $type,
'car_info' => $car_info,
'list' => $list,
'success_items' => $success_items,
'failure_items' => $failure_items,
'next_id' => $next_id,
'next_index' => $next_index,
'car_man' => $car_man,
'car_no' => $car_no,
'phone' => $phone,
'page' => $page,
'sort_key' => $sort_key,
'sort_value' => $sort_value,
'back_params' => $back_params,
// 'gift_type_items' => $gift_type_items,
'business_group_id' => $this->my->business_group_id,
]);
}
//今日预约
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');
$ptype = $request->get('ptype');
$query = AppointmentT::find()
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
->where('appointment_t.is_first=0 and car_t.location=2')
->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($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);
}
$sql = $query->createCommand()->rawSql;
// echo $query->createCommand()->rawSql;
$total = $query->count();
$session->remove('appointment_today');
$session->set('appointment_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(1);
return $this->render('today',[
'items' => $items,
'page_info' => $page_info,
'car_man' => $car_man,
'phone' => $phone,
'car_no' => $car_no,
'ptype' => $ptype,
'list' => $list,
'page' => $page,
'sort_key' => $sort_key,
'sort_value' => $sort_value,
'type' => 2
]);
}
//全部预约
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);
$username = $request->get('username');
$sort_key = $request->get('sort_key','appointment_t.pdate');
$sort_value = $request->get('sort_value','ASC');
$user_id = $request->get('user_id');
$ptype = $request->get('ptype');
$query = AppointmentT::find()
->leftJoin('car_t','`car_t`.`id`=`appointment_t`.`car_id`')
->where('appointment_t.is_first=0 and car_t.location=2');
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($username != '') {
$user_ids = array();
$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]);
else
$query = $query->andWhere('appointment_t.user_id=-1');
}
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('appointment_all');
$session->set('appointment_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();
$user_items = $this->my->getChildren();
$list = MeetT::getAllData(1);
return $this->render('all',[
'items' => $items,
'page_info' => $page_info,
'car_man' => $car_man,
'phone' => $phone,
'ptype' => $ptype,
'list' => $list,
'car_no' => $car_no,
'page' => $page,
'sort_key' => $sort_key,
'sort_value' => $sort_value,
'type' => 3,
'invalid_items' => $invalid_items,
'username' => $username,
'user_items' => $user_items,
'user_id' => $user_id
]);
}
public function actionCount()
{
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');
$query = AppointmentT::find()
->where('pdate="'.$pdate.'" and user_id='.$this->my->id);
$total = $query->count();
$result['success'] = true;
$result['msg'] = '成功';
$result['count'] = $total;
}
return $result;
}
public function actionInvalidA()
{
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) {
// dd($id);
$car_info = CarT::findOne(['id'=>$id]);
$c_info = CleanT::findOne(['id'=>$car_info->id]);
// dd($c_info);
if($c_info) {
$c_info->user_id = 0;
$c_info->yuyue = 1;
$c_info->lingqu_status=1;
$c_info->save();
}
// FiltrationT
//删除预约拨打
//伪删除
// FiltrationT::deleteAll('car_id='.$c_info->id);
$fi_info= FiltrationT::find()->where('car_id='.$c_info->id)->all();
foreach($fi_info as $f){
$f->remark='首次分配';
$f->delete_status=2;
$f->save();
}
// $clean_info= CleanTongji::find()
// ->where('car_id='.$c_info->id)
// ->where('yuyue_num=1')
// ->all();
// foreach($clean_info as $cl_vl){
// $cl_vl->delete();
// }
$this->addLog($car_info->id,'恢复一条数据成功',1);
}
$result['success'] = true;
$result['msg'] = '操作成功';
$tran->commit();
} catch (\Exception $e) {
$tran->rollBack();
echo $e->getMessage();
}
}
return $result;
}
public function actionAssignOther()
{
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());
$user_id = $request->post('user_id');
if($user_id == 0) {
$result['msg'] = '请选择业务员';
return $result;
}
if(count($ids) == 0) {
$result['msg'] = '请先钩选车辆';
return $result;
}
$user_info = UserT::findOne(['id'=>$user_id]);
$tran = CarT::getDb()->beginTransaction();
try {
foreach($ids as $id) {
$car_info = CarT::findOne(['id'=>$id]);
$old_user_info = '';
if($car_info->location == 2) {
$b_info = CarBT::findOne(['id'=>$car_info->id]);
$old_user_info = $b_info->user;
$b_info->user_id = $user_id;
$b_info->save();
$user =$user_info;
// dd($user->getShowName());
if($user) {
$car_info->op_user1 = $user->getShowName();
}
}
if($car_info->location == 3) {
$c_info = CarCT::findOne(['id'=>$car_info->id]);
$old_user_info = $c_info->user;
$c_info->user_id = $user_id;
$c_info->save();
$user = $user_info;
if($user) {
$car_info->op_user2 = $user->getShowName();
}
}
if($car_info->location == 4) {
$d_info = CarDT::findOne(['id'=>$car_info->id]);
$old_user_info = $d_info->user;
$d_info->user_id = $user_id;
$d_info->save();
$user = $user_info;
if($user) {
$car_info->op_user3 = $user->getShowName();
}
}
//库保存
$car_info->save();
$this->addLog($car_info->id,'从'.$old_user_info->getShowName().' 平移车辆给 '.$user_info->getShowName(),1);
//添加保单
OrderT::deleteAll('car_id='.$car_info->id.' and status_id<2');
$order_row = new OrderT();
$order_row->car_id = $car_info->id;
$order_row->car_no = $car_info->car_no;
$order_row->engine_no = $car_info->engine_no;
$order_row->car_frame_no = $car_info->car_frame_no;
$order_row->car_man = $car_info->car_man;
$order_row->user_id = $user_id;
$order_row->status_id = 1;
$order_row->id_man = $car_info->car_man;
$order_row->link_man = $car_info->car_man;
$order_row->link_phone = $car_info->phone;
$order_row->save();
//添加预约
AppointmentT::deleteAll('car_id='.$car_info->id);
$row = new AppointmentT();
$row->car_id = $car_info->id;
$row->user_id = $user_id;
$row->pdate = date('Y-m-d');
$row->ptime = '09:00';
$row->remark = '首次分配';
$row->is_first = 1;
$row->save();
//添加历史预约
$h_row = new AppointmentHistoryT();
$h_row->car_id = $car_info->id;
$h_row->user_id = $user_id;
$h_row->pdate = date('Y-m-d');
$h_row->ptime = '09:00';
$h_row->remark = '首次分配';
$h_row->save();
}
$result['success'] = true;
$result['msg'] = '操作成功';
$tran->commit();
} catch (\Exception $e) {
$tran->rollBack();
throw $e;
}
}
return $result;
}
//分配跟踪业务员
public function actionAssignCpei()
{
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());
// var_dump($ids);
// die;
$user_id = $request->post('user_id');
if($user_id == 0) {
$result['msg'] = '请选择业务员';
return $result;
}
if(count($ids) == 0) {
$result['msg'] = '请先钩选车辆';
return $result;
}
$user_info = UserT::findOne(['id'=>$user_id]);
$tran = CarT::getDb()->beginTransaction();
try {
foreach($ids as $id) {
$car_info = CarT::findOne(['id'=>$id]);
$old_user_info = '';
if($car_info->location == 3) {
$c_info = CarCT::findOne(['id'=>$car_info->id]);
$old_user_info = $c_info->user;
$c_info->user_id = $user_id;
$c_info->save();
//由于事务进行的作用,程序没有进行到底,所执行的数据操作没有进行
//获取post参数的id
$user = $user_info;
// var_dump($user);
// die;
if($user) {
$car_info->op_user2 = $user->getShowName();
}
$car_info -> save();
// var_dump($car_info->op_user2);
// die;
}
$this->addLog($car_info->id,'从'.$old_user_info->getShowName().' 平移车辆给 '.$user_info->getShowName(),1);
//添加保单
OrderT::deleteAll('car_id='.$car_info->id.' and status_id<2');
$order_row = new OrderT();
$order_row->car_id = $car_info->id;
$order_row->car_no = $car_info->car_no;
$order_row->engine_no = $car_info->engine_no;
$order_row->car_frame_no = $car_info->car_frame_no;
$order_row->car_man = $car_info->car_man;
$order_row->user_id = $user_id;
$order_row->status_id = 1;
$order_row->id_man = $car_info->car_man;
$order_row->link_man = $car_info->car_man;
$order_row->link_phone = $car_info->phone;
$order_row->save();
//添加预约
AppointmentT::deleteAll('car_id='.$car_info->id);
$row = new AppointmentT();
$row->car_id = $car_info->id;
$row->user_id = $user_id;
$row->pdate = date('Y-m-d');
$row->ptime = '09:00';
$row->remark = '首次分配';
$row->is_first = 1;
$row->save();
//添加历史预约
$h_row = new AppointmentHistoryT();
$h_row->car_id = $car_info->id;
$h_row->user_id = $user_id;
$h_row->pdate = date('Y-m-d');
$h_row->ptime = '09:00';
$h_row->remark = '首次分配';
$h_row->save();
}
$result['success'] = true;
$result['msg'] = '操作成功';
$tran->commit();
} catch (\Exception $e) {
$tran->rollBack();
throw $e;
}
}
return $result;
}
// public function actionInvalidAllA()
// {
// Yii::$app->response->format = Response::FORMAT_JSON;
// $request = Yii::$app->request;
// $result = array();
// $result['success'] = false;
// $result['msg'] = '操作失败';
//
// if($request->isPost) {
//
// $car_man = $request->post('car_man');
// $phone = $request->post('phone');
// $car_no = $request->post('car_no');
// $page = $request->post('page',1);
// $username = $request->post('username');
// $sort_key = $request->post('sort_key','filtration_t.pdate');
// $sort_value = $request->post('sort_value','ASC');
// $user_id = $request->post('user_id');
//
// $query = FiltrationT::find()
// ->leftJoin('car_t','`car_t`.`id`=`filtration_t`.`car_id`')
// ->andWhere(['!=','`filtration_t`.`remark`','首次分配']);
//
// if($username == '') {
// $user_ids = $this->getChildrenUserIDs();
// $query = $query->andWhere(['in','filtration_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 like "'.$phone.'"');
// }
// if($car_no != '') {
// $query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
// }
// 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','filtration_t.user_id',$user_ids]);
// }
// if($sort_key != '') {
// $query = $query->orderBy($sort_key.' '.$sort_value.',filtration_t.id '.$sort_value);
// }
//
//
// $tran = CarT::getDb()->beginTransaction();
// try {
// foreach($query->each(1000) as $item) {
// $car_info = $item->car;
// //伪删除
// $item->remark='首次分配';
// $item->delete_status=2;
// $item->save();
//
// $c_info = CleanT::findOne(['id'=>$car_info->id]);
//
// if($c_info) {
// $c_info->user_id = 0;
// $c_info->yuyue = 1;
// $c_info->lingqu_status=1;
// $c_info->save();
// }
//
//// FiltrationT
// //删除预约拨打
//// FiltrationT::deleteAll('car_id='.$c_info->id);
// $this->addLog($item->id,'从预约列表数据中恢复清洗库数据',1);
// }
//
// $result['success'] = true;
// $result['msg'] = '操作成功';
//
// $tran->commit();
// } catch (\Exception $e) {
// $tran->rollBack();
// throw $e;
// }
// }
// return $result;
// }
// public function actionInvalidAllA()
// {
// Yii::$app->response->format = Response::FORMAT_JSON;
// $request = Yii::$app->request;
// $result = array();
// $result['success'] = false;
// $result['msg'] = '操作失败';
//
// if($request->isPost) {
//
// $car_man = $request->post('car_man');
// $phone = $request->post('phone');
// $car_no = $request->post('car_no');
// $page = $request->post('page',1);
// $username = $request->post('username');
// $sort_key = $request->post('sort_key','filtration_t.pdate');
// $sort_value = $request->post('sort_value','ASC');
// $user_id = $request->post('user_id');
// $register_begin = $request->post('register_begin');
// $register_end = $request->post('register_end');
// $insurer1_begin = $request->post('insurer1_begin');
// $insurer1_end = $request->post('insurer1_end');
// $insurer1_month = $request->post('insurer1_month');
// $insurer1_day = $request->post('insurer1_day');
// $insurer1_month1 = $request->post('insurer1_month1');
// $insurer1_day1 = $request->post('insurer1_day1');
//
// $query = FiltrationT::find()
// ->leftJoin('car_t','`car_t`.`id`=`filtration_t`.`car_id`')
// ->andWhere(['!=','`filtration_t`.`remark`','首次分配']);
//
// if($username == '') {
// $user_ids = $this->getChildrenUserIDs();
// $query = $query->andWhere(['in','filtration_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 like "'.$phone.'"');
// }
// if($car_no != '') {
// $query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
// }
// 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','filtration_t.user_id',$user_ids]);
// }
// if($sort_key != '') {
// $query = $query->orderBy($sort_key.' '.$sort_value.',filtration_t.id '.$sort_value);
// }
// if($register_begin != '') {
// $query = $query->andWhere('register_date>="'.$register_begin.'"');
// }
// if($register_end != '') {
// $query = $query->andWhere('register_date<="'.$register_end.'"');
// }
//
//// if($insurer1_begin != '') {
//// $query = $query->andWhere('car_t.insurer2_date>="'.$insurer1_begin.'"');
//// }
//// if($insurer1_end != '') {
//// $query = $query->andWhere('car_t.insurer2_date<="'.$insurer1_end.'"');
//// }
// if($insurer1_month != '') {
// $query = $query->andWhere('month(car_t.insurer1_date)>="'.$insurer1_month.'"');
// }
// if($insurer1_day != '') {
// $query = $query->andWhere('day(car_t.insurer1_date)>="'.$insurer1_day.'"');
// }
// if($insurer1_month1 != '') {
// $query = $query->andWhere('month(car_t.insurer1_date)<="'.$insurer1_month1.'"');
// }
// if($insurer1_day1 != '') {
// $query = $query->andWhere('day(car_t.insurer1_date)<="'.$insurer1_day1.'"');
// }
//
// $tran = CarT::getDb()->beginTransaction();
// try {
// foreach($query->each(1000) as $item) {
// $car_info = $item->car;
// //伪删除
// $item->remark='首次分配';
// $item->delete_status=2;
// $item->save();
//
// $c_info = CleanT::findOne(['id'=>$car_info->id]);
//
// if($c_info) {
// $c_info->user_id = 0;
// $c_info->yuyue = 1;
// $c_info->lingqu_status=1;
// $c_info->save();
// }
//
//// FiltrationT
// //删除预约拨打
//// FiltrationT::deleteAll('car_id='.$c_info->id);
// $this->addLog($item->id,'从预约列表数据中恢复清洗库数据',1);
// }
//
// $result['success'] = true;
// $result['msg'] = '操作成功';
//
// $tran->commit();
// } catch (\Exception $e) {
// $tran->rollBack();
// throw $e;
// }
// }
// return $result;
// }
public function actionInvalidAllA()
{
Yii::$app->response->format = Response::FORMAT_JSON;
$request = Yii::$app->request;
$result = array();
$result['success'] = false;
$result['msg'] = '操作失败';
if($request->isPost) {
$car_man = $request->post('car_man');
$phone = $request->post('phone');
$car_no = $request->post('car_no');
$page = $request->post('page',1);
$username = $request->post('username');
$sort_key = $request->post('sort_key','filtration_t.pdate');
$sort_value = $request->post('sort_value','ASC');
$user_id = $request->post('user_id');
$register_begin = $request->post('register_begin');
$register_end = $request->post('register_end');
$insurer1_begin = $request->post('insurer1_begin');
$insurer1_end = $request->post('insurer1_end');
$insurer1_month = $request->post('insurer1_month');
$insurer1_day = $request->post('insurer1_day');
$insurer1_month1 = $request->post('insurer1_month1');
$insurer1_day1 = $request->post('insurer1_day1');
$query = FiltrationT::find()
->leftJoin('car_t','`car_t`.`id`=`filtration_t`.`car_id`')
->andWhere(['!=','`filtration_t`.`remark`','首次分配']);
if($username == '') {
// $user_ids = $this->getChildrenUserIDs();
// $query = $query->andWhere(['in','filtration_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 like "'.$phone.'"');
}
if($car_no != '') {
$query = $query->andWhere('car_t.car_no like "'.$car_no.'"');
}
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','filtration_t.user_id',$user_ids]);
}
if($sort_key != '') {
$query = $query->orderBy($sort_key.' '.$sort_value.',filtration_t.id '.$sort_value);
}
if($register_begin != '') {
$query = $query->andWhere('register_date>="'.$register_begin.'"');
}
if($register_end != '') {
$query = $query->andWhere('register_date<="'.$register_end.'"');
}
// if($insurer1_begin != '') {
// $query = $query->andWhere('car_t.insurer2_date>="'.$insurer1_begin.'"');
// }
// if($insurer1_end != '') {
// $query = $query->andWhere('car_t.insurer2_date<="'.$insurer1_end.'"');
// }
if($insurer1_month != '') {
$query = $query->andWhere('month(car_t.insurer1_date)>="'.$insurer1_month.'"');
}
if($insurer1_day != '') {
$query = $query->andWhere('day(car_t.insurer1_date)>="'.$insurer1_day.'"');
}
if($insurer1_month1 != '') {
$query = $query->andWhere('month(car_t.insurer1_date)<="'.$insurer1_month1.'"');
}
if($insurer1_day1 != '') {
$query = $query->andWhere('day(car_t.insurer1_date)<="'.$insurer1_day1.'"');
}
$tran = CarT::getDb()->beginTransaction();
try {
foreach($query->each(100) as $item) {
$car_info = $item->car;
//伪删除
$item->remark='首次分配';
$item->delete_status=2;
$item->save();
$c_info = CleanT::findOne(['id'=>$car_info->id]);
if($c_info) {
$c_info->user_id = 0;
$c_info->yuyue = 1;
$c_info->lingqu_status=1;
$c_info->save();
}
// FiltrationT
//删除预约拨打
// FiltrationT::deleteAll('car_id='.$c_info->id);
$this->addLog($item->id,'从预约列表数据中恢复清洗库数据',1);
}
$result['success'] = true;
$result['msg'] = '操作成功';
$tran->commit();
} catch (\Exception $e) {
$tran->rollBack();
throw $e;
}
}
return $result;
}
}