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.
7409 lines
274 KiB
7409 lines
274 KiB
<?php
|
|
|
|
namespace frontend\controllers;
|
|
|
|
use common\libs\MyLib;
|
|
use common\models\AppointmentHistoryT;
|
|
use common\models\AppointmentT;
|
|
use common\models\FiltrationT;
|
|
use common\models\BrandT;
|
|
use common\models\CarBT;
|
|
use common\models\CarCT;
|
|
use common\models\CarET;
|
|
use common\models\CarFT;
|
|
use common\models\CarF1T;
|
|
use common\models\CarF2T;
|
|
use common\models\CarF3T;
|
|
use common\models\CarF4T;
|
|
use common\models\CarF5T;
|
|
use common\models\CarF6T;
|
|
use common\models\CardinfoT;
|
|
use common\models\CarDT;
|
|
use common\models\CarInvalidT;
|
|
use common\models\CarMistakeT;
|
|
use common\models\CarLogT;
|
|
use common\models\CarT;
|
|
use common\models\CarTypeT;
|
|
use common\models\CarUseT;
|
|
use common\models\CleanT;
|
|
use common\models\CleanTongji;
|
|
use common\models\CleanFenpei;
|
|
use common\models\DisplacementT;
|
|
use common\models\InvalidT;
|
|
use common\models\OrderT;
|
|
use common\models\OrderUserT;
|
|
use common\models\PriceT;
|
|
use common\models\RightT;
|
|
use common\models\SeriesT;
|
|
use common\models\UserT;
|
|
use common\models\InvalidNew;
|
|
use Yii;
|
|
use yii\data\Pagination;
|
|
use yii\db\Exception;
|
|
use yii\web\Response;
|
|
use yii\db\Expression;
|
|
|
|
class DatabaseController extends BaseController
|
|
{
|
|
public $enableCsrfValidation = false;
|
|
public $layout = 'blue-main';
|
|
|
|
//A库query
|
|
//获取搜索条件
|
|
private function getAQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$engine_no = $request->post('engine_no');
|
|
$car_frame_no = $request->post('car_frame_no');
|
|
$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');
|
|
$b_lib = $request->post('b_lib');
|
|
$c_lib = $request->post('c_lib');
|
|
$d_lib = $request->post('d_lib');
|
|
$e_lib = $request->post('e_lib');
|
|
$invalid_lib = $request->post('invalid_lib');
|
|
$unsel_lib = $request->post('unsel_lib');
|
|
$has_phone = $request->post('has_phone');
|
|
$company = $request->post('company');
|
|
$user1 = $request->post('user1');
|
|
$no_insurerdate = $request->post('no_insurerdate');
|
|
$clean_right = $request->post('clean_right');
|
|
$biaozhu = $request->post('biaozhu');
|
|
} else {
|
|
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$engine_no = $request->get('engine_no');
|
|
$car_frame_no = $request->get('car_frame_no');
|
|
$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');
|
|
$b_lib = $request->get('b_lib');
|
|
$c_lib = $request->get('c_lib');
|
|
$d_lib = $request->get('d_lib');
|
|
$e_lib = $request->get('e_lib');
|
|
$invalid_lib = $request->get('invalid_lib');
|
|
$unsel_lib = $request->get('unsel_lib');
|
|
$has_phone = $request->get('has_phone');
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
$no_insurerdate = $request->get('no_insurerdate');
|
|
$clean_right = $request->get('clean_right');
|
|
$biaozhu = $request->get('biaozhu');
|
|
}
|
|
$params = array();
|
|
$params['car_man'] = $car_man;
|
|
$params['phone'] = $phone;
|
|
$params['car_no'] = $car_no;
|
|
$params['engine_no'] = $engine_no;
|
|
$params['car_frame_no'] = $car_frame_no;
|
|
$params['register_begin'] = $register_begin;
|
|
$params['register_end'] = $register_end;
|
|
$params['insurer1_begin'] = $insurer1_begin;
|
|
$params['insurer1_end'] = $insurer1_end;
|
|
$params['insurer1_month'] = $insurer1_month;
|
|
$params['insurer1_day'] = $insurer1_day;
|
|
$params['insurer1_month1'] = $insurer1_month1;
|
|
$params['insurer1_day1'] = $insurer1_day1;
|
|
$params['b_lib'] = $b_lib;
|
|
$params['c_lib'] = $c_lib;
|
|
$params['d_lib'] = $d_lib;
|
|
$params['e_lib'] = $e_lib;
|
|
$params['invalid_lib'] = $invalid_lib;
|
|
$params['unsel_lib'] = $unsel_lib;
|
|
$params['has_phone'] = $has_phone;
|
|
$params['company'] = $company;
|
|
$params['user1'] = $user1;
|
|
$params['no_insurerdate'] = $no_insurerdate;
|
|
$params['clean_right'] = $clean_right;
|
|
$params['biaozhu'] = $biaozhu;
|
|
|
|
$query = CarT::find();
|
|
|
|
$libs = array();
|
|
if($b_lib == 1) {
|
|
$libs[] = 2;
|
|
}
|
|
if($c_lib == 1) {
|
|
$libs[] = 3;
|
|
}
|
|
if($d_lib == 1) {
|
|
$libs[] = 4;
|
|
}
|
|
if($e_lib == 1) {
|
|
$libs[] = 6;
|
|
}
|
|
if($invalid_lib == 1) {
|
|
$libs[] = 5;
|
|
}
|
|
if($unsel_lib == 1) {
|
|
$libs[] = 1;
|
|
}
|
|
if(count($libs) > 0)
|
|
$query->andWhere(['in','location',$libs]);
|
|
|
|
if($car_man != '') {
|
|
$query->andWhere('car_man like "'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query->andWhere('phone like "'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
$query->andWhere('car_no like "'.$car_no.'%"');
|
|
}
|
|
if($engine_no != '') {
|
|
$query->andWhere('engine_no="'.$engine_no.'"');
|
|
}
|
|
if($car_frame_no != '') {
|
|
$query->andWhere('car_frame_no="'.$car_frame_no.'"');
|
|
}
|
|
if($register_begin != '') {
|
|
$query->andWhere('register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query->andWhere('register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query->andWhere('insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query->andWhere('insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($insurer1_month != '') {
|
|
$query->andWhere('month(car_t.insurer1_date)>="'.$insurer1_month.'"');
|
|
}
|
|
if($insurer1_day != '') {
|
|
$query->andWhere('day(car_t.insurer1_date)>="'.$insurer1_day.'"');
|
|
}
|
|
if($insurer1_month1 != '') {
|
|
$query->andWhere('month(car_t.insurer1_date)<="'.$insurer1_month1.'"');
|
|
}
|
|
if($insurer1_day1 != '') {
|
|
$query->andWhere('day(car_t.insurer1_date)<="'.$insurer1_day1.'"');
|
|
}
|
|
if($clean_right != '') {
|
|
$query->andWhere('car_t.clean_right="'.$clean_right.'"');
|
|
}
|
|
if($biaozhu != '') {
|
|
$query->andWhere('car_t.biaozhu="'.$biaozhu.'"');
|
|
}
|
|
|
|
if($has_phone == 1) {
|
|
$query->andWhere('phone<>""');
|
|
}
|
|
if($no_insurerdate == 1) {
|
|
$query->andWhere('insurer1_date="" or insurer1_date is null or insurer1_date="0000-00-00"');
|
|
}
|
|
if($company != '') {
|
|
$query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query->andWhere('op_user1 like "'.$user1.'%"');
|
|
}
|
|
return ['query'=>$query,'params'=>$params];
|
|
}
|
|
//A库列表页
|
|
public function actionAIndex() {
|
|
$invalid_items = InvalidT::getTree();
|
|
return $this->render('a-index',[
|
|
'invalid_items' => $invalid_items
|
|
]);
|
|
}
|
|
//A库列表数据
|
|
public function actionAIndexJson()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$offset = $request->get('offset',0);
|
|
$limit = $request->get('limit', 10);
|
|
|
|
$data = $this->getAQuery($request);
|
|
|
|
$query = $data['query'];
|
|
// $query->andWhere('location=1');
|
|
|
|
$total = $query->count();
|
|
|
|
$query->orderBy('id desc');
|
|
$query = $query->offset($offset)->limit($limit);
|
|
$items = $query->all();
|
|
|
|
$data = [];
|
|
$data['total'] = $total;
|
|
$data['rows'] = [];
|
|
foreach($items as $item) {
|
|
$row = $item->toArray();
|
|
$row['factory_model'] = MyLib::substr_cut($item->factory_model, 8);
|
|
$row['car_man'] = MyLib::substr_cut($item->car_man, 8);
|
|
$row['location_name'] = $item->getLocation();
|
|
$data['rows'][] = $row;
|
|
}
|
|
return $data;
|
|
}
|
|
//钩选A库到B库
|
|
public function actionAB()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
if($car_info->location == 1) {
|
|
$car_info->location = 2;
|
|
if(!$car_info->save(false)) {
|
|
throw new Exception(print_r($car_info->getFirstErrors(),true));
|
|
}
|
|
|
|
$b_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$b_info) {
|
|
$b_info = new CarBT(false);
|
|
$b_info->id = $car_info->id;
|
|
$b_info->user_id = 0;
|
|
if(!$b_info->save(false)) {
|
|
throw new Exception(print_r($b_info->getFirstErrors(),true));
|
|
}
|
|
}
|
|
$this->addLog($car_info->id,'从A库分配到B库',1);
|
|
}
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
//批量A库到B库
|
|
public function actionABAll()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
$data = $this->getAQuery($request);
|
|
|
|
$query = $data['query'];
|
|
// $query->andWhere('location=1');
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $car_info) {
|
|
if($car_info->location == 1) {
|
|
$car_info->location = 2;
|
|
if(!$car_info->save(false)) {
|
|
throw new Exception(print_r($car_info->getFirstErrors(),true));
|
|
}
|
|
|
|
$b_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$b_info) {
|
|
$b_info = new CarBT(false);
|
|
$b_info->id = $car_info->id;
|
|
$b_info->user_id = 0;
|
|
if(!$b_info->save(false)) {
|
|
throw new Exception(print_r($b_info->getFirstErrors(),true));
|
|
}
|
|
}
|
|
$this->addLog($car_info->id,'从A库分配到B库',1);
|
|
}
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
return $result;
|
|
}
|
|
//钩选A库到C库
|
|
public function actionAC()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',', $request->post('ids'));
|
|
if (count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
if($car_info->location == 1) {
|
|
$car_info->location = 3;
|
|
if(!$car_info->save(false)) {
|
|
throw new Exception(print_r($car_info->getFirstErrors(),true));
|
|
}
|
|
|
|
$c_info = CarCT::findOne(['id'=>$car_info->id]);
|
|
if(!$c_info) {
|
|
$c_info = new CarCT(false);
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = 0;
|
|
if(!$c_info->save(false)) {
|
|
throw new Exception(print_r($c_info->getFirstErrors(),true));
|
|
}
|
|
}
|
|
$this->addLog($car_info->id,'从A库分配到C库',1);
|
|
}
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
}
|
|
//钩选A库到无效库
|
|
public function actionAInvalid()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
$invalid_id = $request->post('invalid_id',0);
|
|
if($invalid_id == 0) {
|
|
$result['msg'] = '请选择无效理由';
|
|
return $result;
|
|
}
|
|
if($ids[0] == '') {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
if($car_info->location == 1) {
|
|
$car_info->location = 5;
|
|
if(!$car_info->save(false)) {
|
|
throw new Exception(print_r($car_info->getFirstErrors(),true));
|
|
}
|
|
|
|
$invalid_info = CarInvalidT::findOne(['id'=>$car_info->id]);
|
|
if(!$invalid_info) {
|
|
$invalid_info = new CarInvalidT(false);
|
|
$invalid_info->id = $car_info->id;
|
|
$invalid_info->user_id = 0;
|
|
$invalid_info->invalid_id = $invalid_id;
|
|
if(!$invalid_info->save(false)) {
|
|
throw new Exception(print_r($invalid_info->getFirstErrors(),true));
|
|
}
|
|
}
|
|
$this->addLog($car_info->id,'从A库移动到无效库',1);
|
|
}
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
//B库
|
|
//获取搜索条件
|
|
private function getBQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->post('insurer1_day');
|
|
$insurer1_month1 = $request->post('insurer1_date1');
|
|
$insurer1_day1 = $request->post('insurer1_day1');
|
|
$username = $request->post('username');
|
|
$status = $request->post('status');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$company = $request->post('company');
|
|
$clean_right = $request->post('clean_right');
|
|
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$company = $request->get('company');
|
|
$clean_right = $request->get('clean_right');
|
|
}
|
|
$query = CarBT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_b_t`.`id`');
|
|
|
|
if($car_man != '') {
|
|
$query->andWhere('car_t.car_man like "'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query->andWhere('car_t.phone like "'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
if($car_no == '非京'){
|
|
$query->andWhere('car_no not like "京%"');
|
|
}else{
|
|
$query->andWhere('car_no like "'.$car_no.'%"');
|
|
}
|
|
}
|
|
if($register_begin != '') {
|
|
$query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($status == 1) {
|
|
$query->andWhere('car_b_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query->andWhere('car_b_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query->andWhere('car_b_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($company != '') {
|
|
$query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_b_t.id '.$sort_value);
|
|
return ['query'=>$query];
|
|
}
|
|
//B库列表页
|
|
public function actionBIndex()
|
|
{
|
|
$user_items = $this->my->getChildren();
|
|
$invalid_items = InvalidT::getTree();
|
|
return $this->render('b-index',[
|
|
'user_items' => $user_items,
|
|
'invalid_items' => $invalid_items
|
|
]);
|
|
}
|
|
//B库列表数据
|
|
public function actionBIndexJson()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$offset = $request->get('offset',0);
|
|
$limit = $request->get('limit', 10);
|
|
|
|
$data = $this->getBQuery($request);
|
|
|
|
$query = $data['query'];
|
|
// $query->andWhere('location=1');
|
|
|
|
$total = $query->count();
|
|
|
|
$query->orderBy('id desc');
|
|
$query = $query->offset($offset)->limit($limit);
|
|
// echo $query->createCommand()->rawSql;
|
|
$items = $query->all();
|
|
|
|
$data = [];
|
|
$data['total'] = $total;
|
|
$data['rows'] = [];
|
|
foreach($items as $item) {
|
|
$car_info = $item->car;
|
|
if(!$car_info) continue;
|
|
$row = $car_info->toArray();
|
|
$row['factory_model'] = MyLib::substr_cut($car_info->factory_model, 8);
|
|
$row['car_man'] = MyLib::substr_cut($car_info->car_man, 8);
|
|
$row['op_user'] = $item->user?$item->user->getShowName():'';
|
|
$data['rows'][] = $row;
|
|
}
|
|
return $data;
|
|
}
|
|
//勾选B库分配
|
|
public function actionBAssign()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
$user_id = $request->post('user_id',0);
|
|
//针对数据处理的数据
|
|
if($user_id == 0) {
|
|
$result['msg'] = '请先选择分配给哪个业务员';
|
|
return $result;
|
|
}
|
|
if($ids[0] == '') {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$b_info = CarBT::findOne(['id'=>$id]);
|
|
if($b_info->user_id > 0) {
|
|
continue;
|
|
}
|
|
$b_info->user_id = $user_id;
|
|
if(!$b_info->save()) {
|
|
throw new \Exception(print_r($b_info->getErrors(),true));
|
|
}
|
|
|
|
//添加保单
|
|
$order_row = new OrderT();
|
|
$order_row->car_id = $b_info->id;
|
|
$order_row->car_no = $b_info->car->car_no;
|
|
$order_row->engine_no = $b_info->car->engine_no;
|
|
$order_row->car_frame_no = $b_info->car->car_frame_no;
|
|
$order_row->car_man = $b_info->car->car_man;
|
|
$order_row->car_man_number = $b_info->car->car_man_number;
|
|
$order_row->car_man_phone = $b_info->car->phone;
|
|
$order_row->user_id = $user_id;
|
|
$order_row->status_id = 1;
|
|
$order_row->id_man = $b_info->car->car_man;
|
|
$order_row->id_man_number = $b_info->car->id_number;
|
|
$order_row->link_man = $b_info->car->car_man;
|
|
$order_row->link_man_phone = $b_info->car->phone;
|
|
$order_row->link_man_number = $b_info->car->id_number;
|
|
if(!$order_row->save()) {
|
|
throw new \Exception(print_r($order_row->getErrors(),true));
|
|
}
|
|
|
|
//添加保单操作员
|
|
$order_user_info = new OrderUserT();
|
|
$order_user_info->user_id = $user_id;
|
|
$order_user_info->order_id = $order_row->id;
|
|
$order_user_info->type_id = 1;
|
|
$order_user_info->status = 0;
|
|
if(!$order_user_info->save()) {
|
|
throw new \Exception(print_r($order_user_info->getErrors(),true));
|
|
}
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$b_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $b_info->id;
|
|
$row->user_id = $user_id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptype = 0;
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
if(!$row->save()) {
|
|
throw new \Exception(print_r($row->getErrors(),true));
|
|
}
|
|
|
|
//添加历史预约
|
|
$h_row = new AppointmentHistoryT();
|
|
$h_row->car_id = $b_info->id;
|
|
$h_row->user_id = $user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptype = 0;
|
|
$h_row->ptime = '09:00';
|
|
$h_row->remark = '首次分配';
|
|
$h_row->xdate = date('Y-m-d');
|
|
$h_row->xtime = '09:00';
|
|
$h_row->xbao = 2;
|
|
if(!$h_row->save()) {
|
|
throw new \Exception(print_r($h_row->getErrors(),true));
|
|
}
|
|
|
|
$this->addLog($b_info->id,'从B库分配数据给业务员:'.$b_info->user->getShowName(),1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
//勾选B库回收
|
|
public function actionBReturn()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
if($ids[0] == '') {
|
|
$result['msg'] = '请先钩选需要操作的车辆';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$b_info = CarBT::findOne(['id'=>$id]);
|
|
$this->addLog($b_info->id,'从B库业务手中回收数据',1);
|
|
|
|
//删除预约
|
|
AppointmentT::deleteAll('car_id='.$b_info->id);
|
|
|
|
//删除保单 还没有正本生成的保单可以直接删除,正本生成后,需要退单操作
|
|
//删除操作人员
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$b_info->id.' and status_id<5')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
OrderUserT::deleteAll('order_id='.$order_info->id);
|
|
//删除保单
|
|
$order_info->delete();
|
|
}
|
|
$b_info->user_id = 0;
|
|
$b_info->save();
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
//批量B库分配
|
|
public function actionBAllAssign()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
$assign_users = explode(',',$request->post('assign_users'));
|
|
$assign_count = $request->post('assign_count',0);
|
|
$assign_user_ids = array();
|
|
foreach($assign_users as $assign_user) {
|
|
$user_info = UserT::findOne(['username'=>$assign_user,'is_delete'=>0]);
|
|
if($user_info)
|
|
$assign_user_ids[] = $user_info->id;
|
|
}
|
|
if(count($assign_user_ids) == 0) {
|
|
$result['msg'] = '请输入业务员工号,以英文逗号间隔';
|
|
return $result;
|
|
}
|
|
if($assign_count == 0) {
|
|
$result['msg'] = '请输入每个业务员分配记录数';
|
|
return $result;
|
|
}
|
|
|
|
$data = $this->getBQuery($request);
|
|
$query = $data['query'];
|
|
// var_dump($query);
|
|
// echo $query->createCommand()->rawSql;
|
|
// echo $query->count();
|
|
// exit;
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
$page = 0;
|
|
$total_pages = count($assign_user_ids);
|
|
$index = 0;
|
|
foreach($query->each(100) as $b_info) {
|
|
if($index >= ($page+1) * $assign_count) $page += 1;
|
|
if($page == $total_pages) break;
|
|
if($b_info->user_id > 0) continue;
|
|
$b_info->user_id = $assign_user_ids[$page];
|
|
if(!$b_info->save()) {
|
|
throw new \Exception(print_r($b_info->getErrors(),true));
|
|
}
|
|
|
|
$car_info = $b_info->car;
|
|
$car_info->op_user1 = $b_info->user->getShowName();
|
|
if(!$car_info->save(false)) {
|
|
throw new \Exception(print_r($car_info->getErrors(), true));
|
|
}
|
|
|
|
//添加保单
|
|
$order_row = new OrderT();
|
|
$order_row->car_id = $b_info->id;
|
|
$order_row->car_no = $b_info->car->car_no;
|
|
$order_row->engine_no = $b_info->car->engine_no;
|
|
$order_row->car_frame_no = $b_info->car->car_frame_no;
|
|
$order_row->car_man = $b_info->car->car_man;
|
|
$order_row->user_id = $b_info->user_id;
|
|
$order_row->status_id = 1;
|
|
$order_row->id_man = $b_info->car->car_man;
|
|
$order_row->link_man = $b_info->car->car_man;
|
|
$order_row->link_man_phone = $b_info->car->phone;
|
|
$order_row->link_man_number = $b_info->car->id_number;
|
|
$order_row->return_status_id = 0;
|
|
$order_row->return_remark = '';
|
|
if(!$order_row->save()) {
|
|
throw new \Exception(print_r($order_row->getErrors(),true));
|
|
}
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$b_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $b_info->id;
|
|
$row->user_id = $b_info->user_id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptime = '09:00';
|
|
$row->ptype = 0;
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
if(!$row->save()) {
|
|
throw new \Exception(print_r($row->getErrors(),true));
|
|
}
|
|
|
|
//添加历史预约
|
|
$h_row = new AppointmentHistoryT();
|
|
$h_row->car_id = $b_info->id;
|
|
$h_row->user_id = $b_info->user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptime = '09:00';
|
|
$h_row->ptype = 0;
|
|
$h_row->remark = '首次分配';
|
|
$h_row->xdate = date('Y-m-d');
|
|
$h_row->xtime = '09:00';
|
|
$h_row->xbao = 2;
|
|
if(!$h_row->save()) {
|
|
throw new \Exception(print_r($h_row->getErrors(),true));
|
|
}
|
|
|
|
$this->addLog($b_info->id,'从B库分配数据给业务员:'.$b_info->user->getShowName(),1);
|
|
$index++;
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
//批量B库回收
|
|
public function actionBReturnAllA()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
|
|
$status = $request->post('status');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
|
|
$query = CarBT::find()
|
|
->leftJoin('car_t','`car_t`.`id`=`car_b_t`.`id`');
|
|
|
|
if($register_begin != '') {
|
|
$query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query->andWhere('car_t.insurer1_end<="'.$insurer1_end.'"');
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
//删除预约
|
|
AppointmentT::deleteAll('car_id='.$item->id);
|
|
|
|
//删除保单 还没有正本生成的保单可以直接删除,正本生成后,需要退单操作
|
|
//删除操作人员
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$item->id.' and status_id<5')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
OrderUserT::deleteAll('order_id='.$order_info->id);
|
|
//删除保单
|
|
$order_info->delete();
|
|
}
|
|
|
|
$item->user_id = 0;
|
|
$item->save();
|
|
// FiltrationT
|
|
//删除预约拨打
|
|
// FiltrationT::deleteAll('car_id='.$c_info->id);
|
|
$this->addLog($item->id,'从B库业务员手中批量回收数据',1);
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
//C库
|
|
//C库列表页
|
|
private function getCQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$print_begin = $request->post('print_begin');
|
|
$print_end = $request->post('print_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');
|
|
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$company = $request->post('company');
|
|
$user1 = $request->post('user1');
|
|
$clean_right = $request->post('clean_right');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
$clean_right = $request->get('clean_right');
|
|
}
|
|
$query = CarCT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_c_t`.`id`');
|
|
|
|
if($car_man != '') {
|
|
$query->andWhere('car_t.car_man like "'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query->andWhere('car_t.phone like "'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
$query->andWhere('car_t.car_no like "'.$car_no.'"');
|
|
}
|
|
if($print_begin != '') {
|
|
$query->andWhere('car_t.print_date>="'.$print_begin.'"');
|
|
}
|
|
if($print_end != '') {
|
|
$query->andWhere('car_t.print_date<="'.$print_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($insurer1_month != '') {
|
|
$query->andWhere('month(car_t.insurer1_date)>="'.$insurer1_month.'"');
|
|
}
|
|
if($insurer1_day != '') {
|
|
$query->andWhere('day(car_t.insurer1_date)>="'.$insurer1_day.'"');
|
|
}
|
|
if($insurer1_month1 != '') {
|
|
$query->andWhere('month(car_t.insurer1_date)<="'.$insurer1_month1.'"');
|
|
}
|
|
if($insurer1_day1 != '') {
|
|
$query->andWhere('day(car_t.insurer1_date)<="'.$insurer1_day1.'"');
|
|
}
|
|
|
|
if($status == 1) {
|
|
$query->andWhere('car_c_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query->andWhere('car_c_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query->andWhere('car_c_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query->andWhere('car_t.old_user="'.$old_user.'"');
|
|
}
|
|
if($company != '') {
|
|
$query->andWhere('company like"'.$company.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query->andWhere('op_user1 like "'.$user1.'%"');
|
|
}
|
|
if($clean_right != '') {
|
|
$query->andWhere('car_t.clean_right="'.$clean_right.'"');
|
|
}
|
|
$query->orderBy($sort_key.' '.$sort_value.', car_c_t.id '.$sort_value);
|
|
return ['query'=>$query];
|
|
}
|
|
public function actionCIndex()
|
|
{
|
|
$user_items = $this->my->getChildren();
|
|
$invalid_items = InvalidT::getTree();
|
|
return $this->render('c-index',[
|
|
'user_items' => $user_items,
|
|
'invalid_items' => $invalid_items
|
|
]);
|
|
}
|
|
public function actionCIndexJson()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$offset = $request->get('offset',0);
|
|
$limit = $request->get('limit', 10);
|
|
|
|
$data = $this->getCQuery($request);
|
|
$query = $data['query'];
|
|
// $query->andWhere('location=1');
|
|
|
|
$total = $query->count();
|
|
|
|
$query->orderBy('id desc');
|
|
$query = $query->offset($offset)->limit($limit);
|
|
$items = $query->all();
|
|
|
|
$data = [];
|
|
$data['total'] = $total;
|
|
$data['rows'] = [];
|
|
foreach($items as $item) {
|
|
$car_info = $item->car;
|
|
if(!$car_info) continue;
|
|
$row = $car_info->toArray();
|
|
$row['factory_model'] = MyLib::substr_cut($car_info->factory_model, 8);
|
|
$row['car_man'] = MyLib::substr_cut($car_info->car_man, 8);
|
|
$row['op_user'] = $item->user?$item->user->getShowName():'';
|
|
$data['rows'][] = $row;
|
|
}
|
|
return $data;
|
|
}
|
|
public function actionCAssign()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
$user_id = $request->post('user_id',0);
|
|
//针对数据处理的数据
|
|
if($user_id == 0) {
|
|
$result['msg'] = '请先选择分配给哪个业务员';
|
|
return $result;
|
|
}
|
|
if($ids[0] == '') {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$c_info = CarCT::findOne(['id'=>$id]);
|
|
if($c_info->user_id > 0) {
|
|
continue;
|
|
}
|
|
$c_info->user_id = $user_id;
|
|
if(!$c_info->save()) {
|
|
throw new \Exception(print_r($c_info->getErrors(),true));
|
|
}
|
|
|
|
//添加保单
|
|
$order_row = new OrderT();
|
|
$order_row->car_id = $c_info->id;
|
|
$order_row->car_no = $c_info->car->car_no;
|
|
$order_row->engine_no = $c_info->car->engine_no;
|
|
$order_row->car_frame_no = $c_info->car->car_frame_no;
|
|
$order_row->car_man = $c_info->car->car_man;
|
|
$order_row->car_man_number = $c_info->car->car_man_number;
|
|
$order_row->car_man_phone = $c_info->car->phone;
|
|
$order_row->user_id = $user_id;
|
|
$order_row->status_id = 1;
|
|
$order_row->id_man = $c_info->car->car_man;
|
|
$order_row->id_man_number = $c_info->car->id_number;
|
|
$order_row->link_man = $c_info->car->car_man;
|
|
$order_row->link_man_phone = $c_info->car->phone;
|
|
$order_row->link_man_number = $c_info->car->id_number;
|
|
if(!$order_row->save()) {
|
|
throw new \Exception(print_r($order_row->getErrors(),true));
|
|
}
|
|
|
|
//添加保单操作员
|
|
$order_user_info = new OrderUserT();
|
|
$order_user_info->user_id = $user_id;
|
|
$order_user_info->order_id = $order_row->id;
|
|
$order_user_info->type_id = 1;
|
|
$order_user_info->status = 0;
|
|
if(!$order_user_info->save()) {
|
|
throw new \Exception(print_r($order_user_info->getErrors(),true));
|
|
}
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$c_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $c_info->id;
|
|
$row->user_id = $user_id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptype = 0;
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
if(!$row->save()) {
|
|
throw new \Exception(print_r($row->getErrors(),true));
|
|
}
|
|
|
|
//添加历史预约
|
|
$h_row = new AppointmentHistoryT();
|
|
$h_row->car_id = $c_info->id;
|
|
$h_row->user_id = $user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptype = 0;
|
|
$h_row->ptime = '09:00';
|
|
$h_row->remark = '首次分配';
|
|
$h_row->xdate = date('Y-m-d');
|
|
$h_row->xtime = '09:00';
|
|
$h_row->xbao = 2;
|
|
if(!$h_row->save()) {
|
|
throw new \Exception(print_r($h_row->getErrors(),true));
|
|
}
|
|
|
|
$this->addLog($c_info->id,'从C库分配数据给业务员:'.$c_info->user->getShowName(),1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionCReturn()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
|
|
if($ids[0] == '') {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$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;
|
|
if(!$car_info->save()) {
|
|
throw new \Exception(print_r($car_info->getErrors(),true));
|
|
}
|
|
|
|
$c_info->user_id = 0;
|
|
if(!$c_info->save()) {
|
|
throw new \Exception(print_r($c_info->getErrors(),true));
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionCAllAssign()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
$assign_users = explode(',',$request->post('assign_users'));
|
|
$assign_count = $request->post('assign_count',0);
|
|
$assign_user_ids = array();
|
|
foreach($assign_users as $assign_user) {
|
|
$user_info = UserT::findOne(['username'=>$assign_user,'is_delete'=>0]);
|
|
if($user_info)
|
|
$assign_user_ids[] = $user_info->id;
|
|
}
|
|
if(count($assign_user_ids) == 0) {
|
|
$result['msg'] = '请输入业务员工号,以英文逗号间隔';
|
|
return $result;
|
|
}
|
|
if($assign_count == 0) {
|
|
$result['msg'] = '请输入每个业务员分配记录数';
|
|
return $result;
|
|
}
|
|
|
|
$data = $this->getCQuery($request);
|
|
$query = $data['query'];
|
|
// var_dump($query);
|
|
// echo $query->createCommand()->rawSql;
|
|
// echo $query->count();
|
|
// exit;
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
$page = 0;
|
|
$total_pages = count($assign_user_ids);
|
|
$index = 0;
|
|
foreach($query->each(100) as $c_info) {
|
|
if($index >= ($page+1) * $assign_count) $page += 1;
|
|
if($page == $total_pages) break;
|
|
if($c_info->user_id > 0) continue;
|
|
$c_info->user_id = $assign_user_ids[$page];
|
|
if(!$c_info->save()) {
|
|
throw new \Exception(print_r($c_info->getErrors(),true));
|
|
}
|
|
|
|
$car_info = $c_info->car;
|
|
$car_info->op_user1 = $c_info->user->getShowName();
|
|
if(!$car_info->save(false)) {
|
|
throw new \Exception(print_r($car_info->getErrors(), true));
|
|
}
|
|
|
|
//添加保单
|
|
$order_row = new OrderT();
|
|
$order_row->car_id = $c_info->id;
|
|
$order_row->car_no = $c_info->car->car_no;
|
|
$order_row->engine_no = $c_info->car->engine_no;
|
|
$order_row->car_frame_no = $c_info->car->car_frame_no;
|
|
$order_row->car_man = $c_info->car->car_man;
|
|
$order_row->car_man_number = $c_info->car->car_man_number;
|
|
$order_row->car_man_phone = $c_info->car->phone;
|
|
$order_row->user_id = $c_info->user_id;
|
|
$order_row->status_id = 1;
|
|
$order_row->id_man = $c_info->car->car_man;
|
|
$order_row->id_man_number = $c_info->car->id_number;
|
|
$order_row->link_man = $c_info->car->car_man;
|
|
$order_row->link_man_phone = $c_info->car->phone;
|
|
$order_row->link_man_number = $c_info->car->id_number;
|
|
if(!$order_row->save()) {
|
|
throw new \Exception(print_r($order_row->getErrors(),true));
|
|
}
|
|
|
|
//添加保单操作员
|
|
$order_user_info = new OrderUserT();
|
|
$order_user_info->user_id = $c_info->user_id;
|
|
$order_user_info->order_id = $order_row->id;
|
|
$order_user_info->type_id = 1;
|
|
$order_user_info->status = 0;
|
|
if(!$order_user_info->save()) {
|
|
throw new \Exception(print_r($order_user_info->getErrors(),true));
|
|
}
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$c_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $c_info->id;
|
|
$row->user_id = $c_info->user_id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptype = 0;
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
if(!$row->save()) {
|
|
throw new \Exception(print_r($row->getErrors(),true));
|
|
}
|
|
|
|
//添加历史预约
|
|
$h_row = new AppointmentHistoryT();
|
|
$h_row->car_id = $c_info->id;
|
|
$h_row->user_id = $c_info->user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptype = 0;
|
|
$h_row->ptime = '09:00';
|
|
$h_row->remark = '首次分配';
|
|
$h_row->xdate = date('Y-m-d');
|
|
$h_row->xtime = '09:00';
|
|
$h_row->xbao = 2;
|
|
if(!$h_row->save()) {
|
|
throw new \Exception(print_r($h_row->getErrors(),true));
|
|
}
|
|
|
|
$this->addLog($c_info->id,'从C库分配数据给业务员:'.$c_info->user->getShowName(),1);
|
|
$index++;
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionCReturnAll()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
|
|
$status = $request->post('status');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
|
|
$query = CarCT::find()
|
|
->leftJoin('car_t','`car_t`.`id`=`car_c_t`.`id`');
|
|
|
|
if($register_begin != '') {
|
|
$query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query->andWhere('car_t.insurer1_end<="'.$insurer1_end.'"');
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
//删除预约
|
|
AppointmentT::deleteAll('car_id='.$item->id);
|
|
|
|
//删除保单 还没有正本生成的保单可以直接删除,正本生成后,需要退单操作
|
|
//删除操作人员
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$item->id.' and status_id<5')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
OrderUserT::deleteAll('order_id='.$order_info->id);
|
|
//删除保单
|
|
$order_info->delete();
|
|
}
|
|
|
|
$item->user_id = 0;
|
|
if(!$item->save()) {
|
|
throw new \Exception(print_r($item->getErrors(), true));
|
|
}
|
|
// FiltrationT
|
|
//删除预约拨打
|
|
// FiltrationT::deleteAll('car_id='.$c_info->id);
|
|
$this->addLog($item->id,'从C库业务员手中批量回收数据',1);
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionCD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
if($car_info->location == 3) {
|
|
$car_info->location = 4;
|
|
if(!$car_info->save(false)) {
|
|
throw new Exception(print_r($car_info->getFirstErrors(),true));
|
|
}
|
|
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
$d_info = CarDT::findOne(['id'=>$car_info->id]);
|
|
if(!$d_info) {
|
|
$d_info = new CarDT(false);
|
|
$d_info->id = $car_info->id;
|
|
$d_info->user_id = 0;
|
|
if(!$d_info->save(false)) {
|
|
throw new Exception(print_r($d_info->getFirstErrors(),true));
|
|
}
|
|
}
|
|
$this->addLog($car_info->id,'从C库分配到D库',1);
|
|
}
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionCAllD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$data = $this->getCQuery($request);
|
|
$query = $data['query'];
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = $c_info->car;
|
|
if($car_info->location == 3) {
|
|
$car_info->location = 4;
|
|
if(!$car_info->save(false)) {
|
|
throw new Exception(print_r($car_info->getFirstErrors(),true));
|
|
}
|
|
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
$d_info = CarDT::findOne(['id'=>$car_info->id]);
|
|
if(!$d_info) {
|
|
$d_info = new CarDT(false);
|
|
$d_info->id = $car_info->id;
|
|
$d_info->user_id = 0;
|
|
if(!$d_info->save(false)) {
|
|
throw new Exception(print_r($d_info->getFirstErrors(),true));
|
|
}
|
|
}
|
|
$this->addLog($car_info->id,'从C库分配到D库',1);
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
//D库列表页
|
|
private function getDQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$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');
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$user1 = $request->post('user1');
|
|
$user2 = $request->post('user2');
|
|
$company = $request->post('company');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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');
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$user1 = $request->get('user1');
|
|
$user2 = $request->get('user2');
|
|
$company = $request->get('company');
|
|
}
|
|
$params = array();
|
|
$params['car_man'] = $car_man;
|
|
$params['phone'] = $phone;
|
|
$params['car_no'] = $car_no;
|
|
$params['insurer1_begin'] = $insurer1_begin;
|
|
$params['insurer1_end'] = $insurer1_end;
|
|
$params['insurer1_month'] = $insurer1_month;
|
|
$params['insurer1_day'] = $insurer1_day;
|
|
$params['insurer1_month1'] = $insurer1_month1;
|
|
$params['insurer1_day1'] = $insurer1_day1;
|
|
$params['status'] = $status;
|
|
$params['username'] = $username;
|
|
$params['sort_key'] = $sort_key;
|
|
$params['sort_value'] = $sort_value;
|
|
$params['old_user'] = $old_user;
|
|
$params['user1'] = $user1;
|
|
$params['user2'] = $user2;
|
|
$params['company'] = $company;
|
|
|
|
$query = CarDT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_d_t`.`id`');
|
|
if($car_man != '') {
|
|
$query->andWhere('car_t.car_man="'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query->andWhere('car_t.phone like "'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
$query->andWhere('car_t.car_no like "'.$car_no.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($insurer1_month != '') {
|
|
$query->andWhere('month(car_t.insurer1_date)>="'.$insurer1_month.'"');
|
|
}
|
|
if($insurer1_day != '') {
|
|
$query->andWhere('day(car_t.insurer1_date)>="'.$insurer1_day.'"');
|
|
}
|
|
if($insurer1_month1 != '') {
|
|
$query->andWhere('month(car_t.insurer1_date)<="'.$insurer1_month1.'"');
|
|
}
|
|
if($insurer1_day1 != '') {
|
|
$query->andWhere('day(car_t.insurer1_date)<="'.$insurer1_day1.'"');
|
|
}
|
|
if($status == 1) {
|
|
$query->andWhere('car_d_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_d_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query->andWhere('car_d_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query->andWhere('car_t.old_user like "'.$old_user.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query->andWhere('car_t.op_user1 like "'.$user1.'%"');
|
|
}
|
|
if($user2 != '') {
|
|
$query->andWhere('car_t.op_user3 like "'.$user2.'%"');
|
|
}
|
|
if($company != '') {
|
|
$query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
$query->orderBy($sort_key.' '.$sort_value.',car_d_t.id '.$sort_value);
|
|
return ['query'=>$query,'params'=>$params];
|
|
}
|
|
public function actionDIndex()
|
|
{
|
|
$user_items = $this->my->getChildren();
|
|
$invalid_items = InvalidT::getTree();
|
|
return $this->render('d-index',[
|
|
'user_items' => $user_items,
|
|
'invalid_items' => $invalid_items
|
|
]);
|
|
}
|
|
public function actionDSearch() {
|
|
return $this->render('d-index-search');
|
|
}
|
|
public function actionDIndexJson()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$offset = $request->get('offset',0);
|
|
$limit = $request->get('limit', 10);
|
|
|
|
$data = $this->getDQuery($request);
|
|
$query = $data['query'];
|
|
// $query->andWhere('location=1');
|
|
$total = $query->count();
|
|
|
|
$query->orderBy('id desc');
|
|
$query = $query->offset($offset)->limit($limit);
|
|
$items = $query->all();
|
|
|
|
$data = [];
|
|
$data['total'] = $total;
|
|
$data['rows'] = [];
|
|
foreach($items as $item) {
|
|
$car_info = $item->car;
|
|
if(!$car_info) continue;
|
|
$row = $car_info->toArray();
|
|
$row['factory_model'] = MyLib::substr_cut($car_info->factory_model, 8);
|
|
$row['car_man'] = MyLib::substr_cut($car_info->car_man, 8);
|
|
$row['op_user'] = $item->user?$item->user->getShowName():'';
|
|
$data['rows'][] = $row;
|
|
}
|
|
return $data;
|
|
}
|
|
public function actionDAssign()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
$user_id = $request->post('user_id',0);
|
|
//针对数据处理的数据
|
|
if($user_id == 0) {
|
|
$result['msg'] = '请先选择分配给哪个业务员';
|
|
return $result;
|
|
}
|
|
if($ids[0] == '') {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$d_info = CarDT::findOne(['id'=>$id]);
|
|
if($d_info->user_id > 0) {
|
|
continue;
|
|
}
|
|
$d_info->user_id = $user_id;
|
|
if(!$d_info->save()) {
|
|
throw new \Exception(print_r($d_info->getErrors(),true));
|
|
}
|
|
|
|
//添加保单
|
|
$order_row = new OrderT();
|
|
$order_row->car_id = $d_info->id;
|
|
$order_row->car_no = $d_info->car->car_no;
|
|
$order_row->engine_no = $d_info->car->engine_no;
|
|
$order_row->car_frame_no = $d_info->car->car_frame_no;
|
|
$order_row->car_man = $d_info->car->car_man;
|
|
$order_row->user_id = $user_id;
|
|
$order_row->status_id = 1;
|
|
$order_row->id_man = $d_info->car->car_man;
|
|
$order_row->link_man = $d_info->car->car_man;
|
|
$order_row->link_phone = $d_info->car->phone;
|
|
if(!$order_row->save()) {
|
|
throw new \Exception(print_r($order_row->getErrors(),true));
|
|
}
|
|
|
|
//添加保单操作员
|
|
$order_user_info = new OrderUserT();
|
|
$order_user_info->user_id = $user_id;
|
|
$order_user_info->order_id = $order_row->id;
|
|
$order_user_info->type_id = 1;
|
|
$order_user_info->status = 0;
|
|
if(!$order_user_info->save()) {
|
|
throw new \Exception(print_r($order_user_info->getErrors(),true));
|
|
}
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$d_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $d_info->id;
|
|
$row->user_id = $user_id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptype = 0;
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
if(!$row->save()) {
|
|
throw new \Exception(print_r($row->getErrors(),true));
|
|
}
|
|
|
|
//添加历史预约
|
|
$h_row = new AppointmentHistoryT();
|
|
$h_row->car_id = $d_info->id;
|
|
$h_row->user_id = $user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptype = 0;
|
|
$h_row->ptime = '09:00';
|
|
$h_row->remark = '首次分配';
|
|
$h_row->xdate = date('Y-m-d');
|
|
$h_row->xtime = '09:00';
|
|
$h_row->xbao = 2;
|
|
if(!$h_row->save()) {
|
|
throw new \Exception(print_r($h_row->getErrors(),true));
|
|
}
|
|
|
|
$this->addLog($d_info->id,'从D库分配数据给业务员:'.$d_info->user->getShowName(),1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionDReturn()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$ids = explode(',',$request->post('ids'));
|
|
|
|
if($ids[0] == '') {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$d_info = CarDT::findOne(['id'=>$id]);
|
|
if($d_info->user_id > 0)
|
|
$this->addLog($d_info->id,'从业务员:'.$d_info->user->getShowName().'回收跟踪数据',1);
|
|
//删除预约
|
|
AppointmentT::deleteAll('user_id='.$d_info->user_id.' and car_id='.$d_info->id);
|
|
|
|
$car_info = $d_info->car;
|
|
$car_info->user_id = 0;
|
|
if(!$car_info->save()) {
|
|
throw new \Exception(print_r($car_info->getErrors(),true));
|
|
}
|
|
|
|
$d_info->user_id = 0;
|
|
if(!$d_info->save()) {
|
|
throw new \Exception(print_r($d_info->getErrors(),true));
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionDAllAssign()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$assign_users = explode(',',$request->post('assign_users'));
|
|
$assign_count = $request->post('assign_count',0);
|
|
$assign_user_ids = array();
|
|
foreach($assign_users as $assign_user) {
|
|
$user_info = UserT::findOne(['username'=>$assign_user]);
|
|
if($user_info)
|
|
$assign_user_ids[] = $user_info->id;
|
|
}
|
|
if(count($assign_user_ids) == 0) {
|
|
$result['msg'] = '请输入业务员工号,以英文逗号间隔';
|
|
return $result;
|
|
}
|
|
if($assign_count == 0) {
|
|
$result['msg'] = '请输入每个业务员分配记录数';
|
|
return $result;
|
|
}
|
|
|
|
$data = $this->getDQuery($request);
|
|
$query = $data['query'];
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
|
|
try {
|
|
$page = 0;
|
|
$total_pages = count($assign_user_ids);
|
|
$index = 0;
|
|
foreach($query->each(100) as $d_info) {
|
|
if($index >= ($page+1) * $assign_count) $page += 1;
|
|
if($page == $total_pages) break;
|
|
if($d_info->user_id > 0) continue;
|
|
|
|
$d_info->user_id = $assign_user_ids[$page];
|
|
if(!$d_info->save()) {
|
|
throw new \Exception(print_r($d_info->getErrors(),true));
|
|
}
|
|
|
|
$car_info = $d_info->car;
|
|
$car_info->op_user3 = $d_info->user->getShowName();
|
|
if(!$car_info->save()) {
|
|
throw new \Exception(print_r($car_info->getErrors(),true));
|
|
}
|
|
|
|
//添加保单
|
|
$order_row = new OrderT();
|
|
$order_row->car_id = $d_info->id;
|
|
$order_row->car_no = $d_info->car->car_no;
|
|
$order_row->engine_no = $d_info->car->engine_no;
|
|
$order_row->car_frame_no = $d_info->car->car_frame_no;
|
|
$order_row->car_man = $d_info->car->car_man;
|
|
$order_row->user_id = $d_info->user_id;
|
|
$order_row->status_id = 1;
|
|
$order_row->id_man = $d_info->car->car_man;
|
|
$order_row->link_man = $d_info->car->car_man;
|
|
$order_row->link_phone = $d_info->car->phone;
|
|
$order_row->return_status_id = 0;
|
|
$order_row->return_remark = '';
|
|
if(!$order_row->save()) {
|
|
throw new \Exception(print_r($order_row->getErrors(),true));
|
|
}
|
|
|
|
//添加保单操作员
|
|
$order_user_info = new OrderUserT();
|
|
$order_user_info->user_id = $d_info->user_id;
|
|
$order_user_info->order_id = $order_row->id;
|
|
$order_user_info->type_id = 1;
|
|
$order_user_info->status = 0;
|
|
if(!$order_user_info->save()) {
|
|
throw new \Exception(print_r($order_user_info->getErrors(),true));
|
|
}
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$d_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $d_info->id;
|
|
$row->user_id = $d_info->user_id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptype = 0;
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
if(!$row->save()) {
|
|
throw new \Exception(print_r($row->getErrors(), true));
|
|
}
|
|
|
|
//添加历史预约
|
|
$h_row = new AppointmentHistoryT();
|
|
$h_row->car_id = $d_info->id;
|
|
$h_row->user_id = $d_info->user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptype = 0;
|
|
$h_row->ptime = '09:00';
|
|
$h_row->remark = '首次分配';
|
|
$h_row->xdate = date('Y-m-d');
|
|
$h_row->xtime = '09:00';
|
|
if(!$h_row->save()) {
|
|
throw new \Exception(print_r($h_row->getErrors(), true));
|
|
}
|
|
|
|
$this->addLog($d_info->id,'从D库分配数据给业务员:'.$d_info->user->getShowName(),1);
|
|
$index++;
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
$result['msg'] = $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
//无效库列表页
|
|
private function getInvalidQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
$invalid_id = $request->post('invalid_id');
|
|
$username = $request->post('username');
|
|
$user1 = $request->post('user1');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$register_begin = $request->get('register_begin');
|
|
$register_end = $request->get('register_end');
|
|
$insurer1_begin = $request->get('insurer1_begin');
|
|
$insurer1_end = $request->get('insurer1_end');
|
|
$invalid_id = $request->get('invalid_id');
|
|
$username = $request->get('username');
|
|
$user1 = $request->get('user1');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
}
|
|
$params = array();
|
|
$params['car_man'] = $car_man;
|
|
$params['phone'] = $phone;
|
|
$params['car_no'] = $car_no;
|
|
$params['register_begin'] = $register_begin;
|
|
$params['register_end'] = $register_end;
|
|
$params['insurer1_begin'] = $insurer1_begin;
|
|
$params['insurer1_end'] = $insurer1_end;
|
|
$params['invalid_id'] = $invalid_id;
|
|
$params['username'] = $username;
|
|
$params['user1'] = $user1;
|
|
$params['sort_key'] = $sort_key;
|
|
$params['sort_value'] = $sort_value;
|
|
|
|
$query = CarInvalidT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_invalid_t`.`id`');
|
|
|
|
if($car_man != '') {
|
|
$query->andWhere('car_t.car_man="'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query->andWhere('car_t.phone="'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
$query->andWhere('car_t.car_no="'.$car_no.'"');
|
|
}
|
|
if($register_begin != '') {
|
|
$query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($invalid_id > 0) {
|
|
$query->andWhere('car_invalid_t.invalid_id='.$invalid_id);
|
|
}
|
|
if($user1 != '') {
|
|
$query->andWhere('car_t.op_user1 like "'.$user1.'%"');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query->andWhere('car_invalid_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
$query->orderBy($sort_key.' '.$sort_value.',car_invalid_t.id '.$sort_value);
|
|
// echo $query->createCommand()->rawSql;
|
|
return ['query'=>$query,'params'=>$params];
|
|
}
|
|
public function actionInvalidIndex()
|
|
{
|
|
$invalid_items = InvalidT::getTree();
|
|
return $this->render('invalid-index',[
|
|
'invalid_items'
|
|
]);
|
|
}
|
|
public function actionInvalidSearch() {
|
|
$invalid_items = InvalidT::getTree();
|
|
return $this->render('invalid-index-search',[
|
|
'invalid_items' => $invalid_items
|
|
]);
|
|
}
|
|
public function actionInvalidIndexJson()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$offset = $request->get('offset',0);
|
|
$limit = $request->get('limit', 10);
|
|
|
|
$data = $this->getInvalidQuery($request);
|
|
$query = $data['query'];
|
|
// $query->andWhere('location=1');
|
|
$total = $query->count();
|
|
|
|
$query->orderBy('id desc');
|
|
$query = $query->offset($offset)->limit($limit);
|
|
$items = $query->all();
|
|
|
|
$data = [];
|
|
$data['total'] = $total;
|
|
$data['rows'] = [];
|
|
foreach($items as $item) {
|
|
$car_info = $item->car;
|
|
if(!$car_info) continue;
|
|
$row = $car_info->toArray();
|
|
$row['factory_model'] = MyLib::substr_cut($car_info->factory_model, 8);
|
|
$row['car_man'] = MyLib::substr_cut($car_info->car_man, 8);
|
|
$row['op_user'] = $item->user?$item->user->getShowName():'';
|
|
$data['rows'][] = $row;
|
|
}
|
|
return $data;
|
|
}
|
|
|
|
public function actionKufangIndex()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
|
|
$data = $this->getAQuery($request);
|
|
$query = $data['query'];
|
|
$params = $data['params'];
|
|
$params['page'] = $page;
|
|
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_t.id=-1');
|
|
}
|
|
// 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();
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
|
|
$params['items'] = $items;
|
|
$params['page_info'] = $page_info;
|
|
$params['invalid_items'] = $invalid_items;
|
|
// $params['month'] = CarT::MONTH;
|
|
// $params['days'] = CarT::DAYS;
|
|
|
|
|
|
return $this->render('kufang-index',$params);
|
|
}
|
|
|
|
public function actionAClean()
|
|
{
|
|
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]);
|
|
if($car_info->location == 1) {
|
|
if($car_info->qiyong==2){
|
|
continue;
|
|
}
|
|
$car_info->location = 14;
|
|
$car_info->save();
|
|
|
|
$c_info = CleanT::findOne(['id'=>$car_info->id]);
|
|
if(!$c_info) {
|
|
$c_info = new CleanT();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = 0;
|
|
// $c_info->save();
|
|
if($c_info->save()){
|
|
$fenpei= new CleanFenpei();
|
|
$fenpei->user_id=$this->my->id;
|
|
$fenpei->fenpei_num=1;
|
|
$fenpei->fenpei_date=date('Y-m-d');
|
|
$fenpei->save();
|
|
|
|
}
|
|
|
|
}
|
|
$this->addLog($car_info->id,'从A库分配到清洗库',1);
|
|
}
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionRightMoveB()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
$flag = 0;
|
|
if($request->isPost) {
|
|
// $unsel_lib = $request->post('unsel_lib',0);
|
|
// $has_phone = $request->post('has_phone');
|
|
|
|
$data = $this->getRightQuery($request);
|
|
$query = $data;
|
|
|
|
// if($unsel_lib == 0) {
|
|
// $result['msg'] = '请先选择未分配选项';
|
|
// return $result;
|
|
// }
|
|
// if($has_phone != 1) {
|
|
// $result['msg'] = '请先选择有电话号码选项';
|
|
// return $result;
|
|
// }
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
$car_info = $item->car;
|
|
if($car_info->location == 15) {
|
|
$car_info->location = 2;
|
|
$car_info->save();
|
|
|
|
$b_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$b_info) {
|
|
$b_info = new CarBT();
|
|
$b_info->id = $car_info->id;
|
|
$b_info->user_id = 0;
|
|
$b_info->save();
|
|
|
|
$this->addLog($car_info->id,'批量从清洗库分配到B库',1);
|
|
}
|
|
}
|
|
$item->delete();
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionRightB()
|
|
{
|
|
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]);
|
|
if($car_info->location == 15) {
|
|
$car_info->location = 2;
|
|
$car_info->save();
|
|
RightT::deleteAll(['id'=>$car_info->id]);
|
|
$b_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$b_info) {
|
|
$b_info = new CarBT();
|
|
$b_info->id = $car_info->id;
|
|
$b_info->user_id = 0;
|
|
$b_info->save();
|
|
}
|
|
$this->addLog($car_info->id,'从数据准确库分配到B库',1);
|
|
}
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionBC()
|
|
{
|
|
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());
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 3;
|
|
$car_info->save();
|
|
|
|
CarBT::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$c_info = new CarCT();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = 0;
|
|
$c_info->save();
|
|
|
|
$this->addLog($car_info->id,'从B库分配到C库',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
|
|
|
|
public function actionCA()
|
|
{
|
|
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());
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 1;
|
|
$car_info->is_track = 0;
|
|
$car_info->save();
|
|
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$this->addLog($car_info->id,'从C库收回到A库',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
***********************************
|
|
* E库到A库
|
|
* 功能
|
|
* @author liukangle
|
|
*********************************
|
|
*/
|
|
public function actionEA()
|
|
{
|
|
|
|
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) {
|
|
|
|
$e_info = CarET::findOne(['id'=>$id]);
|
|
|
|
if($e_info->user_id > 0) {
|
|
$result['msg'] = '被分配的不可恢复到A库';
|
|
return $result;
|
|
}
|
|
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarET::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$this->addLog($car_info->id,'从E库恢复到A库',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionED()
|
|
{
|
|
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) {
|
|
|
|
$e_info = CarET::findOne(['id'=>$id]);
|
|
|
|
if($e_info->user_id > 0) {
|
|
$result['msg'] = '被分配的不可移动到D库';
|
|
return $result;
|
|
}
|
|
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 4;
|
|
$car_info->save();
|
|
|
|
CarET::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$c_info = new CarDT();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = 0;
|
|
$c_info->save();
|
|
|
|
$this->addLog($car_info->id,'从E库分配到D库',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionDC()
|
|
{
|
|
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());
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 3;
|
|
$car_info->save();
|
|
|
|
CarDT::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$c_info = new CarCT();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = 0;
|
|
$c_info->save();
|
|
|
|
$this->addLog($car_info->id,'从D库分配到C库',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionAE()
|
|
{
|
|
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 = CarET::getDb()->beginTransaction();
|
|
try {
|
|
//对id数组进行便利,改变其在A库中的字段位置
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
if($car_info->location == 1){
|
|
if($car_info->qiyong==2){
|
|
continue;
|
|
}
|
|
$car_info->location = 6;
|
|
$car_info->save();
|
|
|
|
//在E库中新加一条记录
|
|
$e_info = CarET::findOne(['id'=>$car_info->id]);
|
|
if(!$e_info){
|
|
$e_info = new CarET();
|
|
$e_info->id = $car_info->id;
|
|
$e_info->user_id = 0;
|
|
$e_info->save();
|
|
}
|
|
$this->addLog($car_info->id,'从A库分配到E库',1);
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
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());
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarInvalidT::deleteAll('id='.$id);
|
|
AppointmentHistoryT::deleteAll('car_id='.$id);
|
|
$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 actionInvalidAllA()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$invalid_id = $request->post('invalid_id');
|
|
|
|
if($invalid_id == 0) {
|
|
$result['msg'] = '请先选择无效理由';
|
|
return $result;
|
|
}
|
|
$data = $this->getInvalidQuery($request);
|
|
$query = $data['query'];
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
$car_info = $item->car;
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
AppointmentHistoryT::deleteAll('car_id='.$item->id);
|
|
$item->delete();
|
|
$this->addLog($item->id,'从无效数据中恢复数据',1);
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionInvalid1A()
|
|
{
|
|
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());
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarF3T::deleteAll('id='.$id);
|
|
|
|
$this->addLog($car_info->id,'从F3无效数据中恢复数据',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionInvalid1AllA()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$invalid_id = $request->post('invalid_id');
|
|
|
|
if($invalid_id == 0) {
|
|
$result['msg'] = '请先选择无效理由';
|
|
return $result;
|
|
}
|
|
$data = $this->getInvalidQuery1($request);
|
|
$query = $data['query'];
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
$car_info = $item->car;
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
$item->delete();
|
|
$this->addLog($item->id,'从F3无效数据中恢复数据',1);
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionInvalid2A()
|
|
{
|
|
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());
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarF6T::deleteAll('id='.$id);
|
|
|
|
$this->addLog($car_info->id,'从F6无效数据中恢复数据',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionInvalid3A()
|
|
{
|
|
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());
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$car_info = CarT::findOne(['id'=>$id]);
|
|
$car_bt=CarBT::findOne(['id'=>$id]);
|
|
$invalid_id=$car_bt->iv_d;
|
|
if($invalid_id == 57 || $invalid_id == 58 || $invalid_id == 59 || $invalid_id ==60 || $invalid_id ==61) {
|
|
if($invalid_id == 61){
|
|
CarF2T::deleteAll('id='.$car_info->id);
|
|
$c_info = new CarF2T();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = 0;
|
|
$c_info->save();
|
|
$car_info->location = 9;
|
|
$car_info->company = '其他小保险公司';
|
|
|
|
}elseif($invalid_id == 57 || $invalid_id == 58 || $invalid_id == 59 || $invalid_id ==60){
|
|
|
|
CarF1T::deleteAll('id='.$car_info->id);
|
|
$c_info = new CarF1T();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = 0;
|
|
|
|
switch($invalid_id) {
|
|
case 57:
|
|
$car_info->company = '人保';
|
|
break;
|
|
case 58:
|
|
$car_info->company = '平安';
|
|
break;
|
|
case 59:
|
|
$car_info->company = '太平洋';
|
|
break;
|
|
case 60:
|
|
$car_info->company = '国寿财';
|
|
break;
|
|
default:
|
|
$car_info->company = '';
|
|
}
|
|
$c_info->save();
|
|
$car_info->location = 8;
|
|
}
|
|
|
|
// $car_info->company = $ac3;
|
|
$car_info->save();
|
|
CarBT::deleteAll(['id'=>$car_info->id]);
|
|
|
|
|
|
//删除预约
|
|
AppointmentT::deleteAll('car_id='.$car_info->id);
|
|
AppointmentHistoryT::deleteAll('car_id='.$car_info->id);
|
|
|
|
//删除保单
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$car_info->id.' and status_id<2')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
OrderUserT::deleteAll('order_id='.$order_info->id);
|
|
$order_info->delete();
|
|
}
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$car_info->id.' and status_id>1')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
$order_user_info = OrderUserT::findOne(['order_id'=>$order_info->id,'status'=>0]);
|
|
if($order_user_info) {
|
|
$order_user_info->status = 3;
|
|
$order_user_info->save();
|
|
}
|
|
}
|
|
if($invalid_id == 61){
|
|
|
|
$this->addLog($car_info->id,'新保销售预约时,已在新保其他小公司,进入F2库',1);
|
|
}elseif($invalid_id == 57 || $invalid_id == 58 || $invalid_id == 59 || $invalid_id ==60){
|
|
|
|
$this->addLog($car_info->id,'新保销售预约时,已在新保四大公司,进入F1库',1);
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
//dd($invalid_id);
|
|
$car_info->location = 10;
|
|
$car_info->save();
|
|
CarF3T::deleteAll('id='.$car_info->id);
|
|
$invalid_info = new CarF3T();
|
|
$invalid_info->id = $car_info->id;
|
|
$invalid_info->invalid_id = $invalid_id;
|
|
$invalid_info->user_id = $this->my->id;
|
|
$invalid_info->save();
|
|
|
|
CarBT::deleteAll(['id'=>$car_info->id]);
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
CarDT::deleteAll(['id'=>$car_info->id]);
|
|
|
|
//删除预约
|
|
AppointmentT::deleteAll('car_id='.$car_info->id);
|
|
|
|
//删除保单
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$car_info->id.' and status_id<2')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
OrderUserT::deleteAll('order_id='.$order_info->id);
|
|
$order_info->delete();
|
|
}
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$car_info->id.' and status_id>1')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
$order_user_info = OrderUserT::findOne(['order_id'=>$order_info->id,'status'=>0]);
|
|
if($order_user_info) {
|
|
$order_user_info->status = 3;
|
|
$order_user_info->save();
|
|
}
|
|
}
|
|
|
|
$this->addLog($car_info->id,'无效车辆数据:'.$invalid_info->invalid->name,1);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarF6T::deleteAll('id='.$id);
|
|
|
|
$this->addLog($car_info->id,'从F6无效数据中恢复数据',1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionInvalid2AllA()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$invalid_id = $request->post('invalid_id');
|
|
|
|
if($invalid_id == 0) {
|
|
$result['msg'] = '请先选择无效理由';
|
|
return $result;
|
|
}
|
|
$data = $this->getInvalidQuery2($request);
|
|
$query = $data['query'];
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
$car_info = $item->car;
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
$item->delete();
|
|
$this->addLog($item->id,'从F6无效数据中恢复数据',1);
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionMistake()
|
|
{
|
|
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');
|
|
$invalid_id = $request->post('invalid_id',0);
|
|
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
|
|
$car_info = CarT::findOne(['id'=>$car_id]);
|
|
// dd($car_info);
|
|
|
|
$clean_info=CleanT::findOne(['id'=>$car_id]);
|
|
|
|
if($invalid_id==70 || $invalid_id==71){
|
|
$car_info->location=1;
|
|
$car_info->qiyong=2;
|
|
$car_info->save();
|
|
$this->addLog($car_info->id,'进入A库永不启用',1);
|
|
}else{
|
|
$car_info->location = 16;
|
|
CarMistakeT::deleteAll('id='.$car_info->id);
|
|
$invalid_info = new CarMistakeT();
|
|
$invalid_info->id = $car_info->id;
|
|
$invalid_info->invalid_id = $invalid_id;
|
|
$invalid_info->user_id = $this->my->id;
|
|
if($clean_info->repeat==1){
|
|
$invalid_info->judge = 1;
|
|
}else{
|
|
$invalid_info->judge = 2;
|
|
}
|
|
$invalid_info->user_id = $this->my->id;
|
|
$invalid_info->save();
|
|
$car_info->save();
|
|
$this->addLog($car_info->id,'不准确车辆数据:'.$invalid_info->invalid->name,1);
|
|
}
|
|
CarBT::deleteAll(['id'=>$car_info->id]);
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
CarDT::deleteAll(['id'=>$car_info->id]);
|
|
CarET::deleteAll(['id'=>$car_info->id]);
|
|
CleanT::deleteAll(['id'=>$car_info->id]);
|
|
$cleantj= new CleanTongji();
|
|
$cleantj->user_id=$this->my->id;
|
|
$cleantj->wrong_num=1;
|
|
$cleantj->yuefen=date('Y-m-d');
|
|
$cleantj->car_id=$car_info->id;
|
|
$cleantj->car_no=$car_info->car_no;
|
|
$cleantj->save();
|
|
|
|
//删除预约
|
|
FiltrationT::deleteAll('car_id='.$car_info->id);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionZhongjiXuanze()
|
|
{
|
|
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');
|
|
$invalid_id = $request->post('invalid_id',0);
|
|
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
|
|
$car_info = CarT::findOne(['id'=>$car_id]);
|
|
// dd($car_info);
|
|
|
|
$clean_info=CleanT::findOne(['id'=>$car_id]);
|
|
|
|
if($invalid_id==76){//准确数据
|
|
|
|
$car_info->location = 15;
|
|
$car_info->clean_right = 1;
|
|
$car_info->clean_num =$car_info->clean_num+1;
|
|
|
|
$car_info->save();
|
|
|
|
$c_info = RightT::findOne(['id' => $car_info->id]);
|
|
if (!$c_info) {
|
|
$c_info = new RightT();
|
|
$c_info->id = $car_info->id;
|
|
if($clean_info->repeat==1){
|
|
$c_info->judge = 1;
|
|
}else{
|
|
$c_info->judge = 2;
|
|
}
|
|
$c_info->user_id = 0;
|
|
$c_info->caozuo_id = $this->my->id;
|
|
$c_info->save();
|
|
|
|
}
|
|
CleanT::deleteAll(['id' => $car_info->id]);
|
|
$cleantj= new CleanTongji();
|
|
$cleantj->user_id=$this->my->id;
|
|
$cleantj->right_num=1;
|
|
$cleantj->yuefen=date('Y-m-d');
|
|
$cleantj->car_id=$car_info->id;
|
|
$cleantj->car_no=$car_info->car_no;
|
|
$cleantj->save();
|
|
|
|
$this->addLog($car_info->id, '从清洗库分配到数据准确库成功', 1);
|
|
|
|
}elseif($invalid_id>63 && $invalid_id<69){ //预约
|
|
|
|
if($clean_info){
|
|
$clean_info->yuyue=2;
|
|
$clean_info->lingqu_status=2;
|
|
$clean_info->save();
|
|
}
|
|
$cleantj_info=CleanTongji::find()->where(['car_id'=>$car_id])->andWhere(['user_id'=>$this->my->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);
|
|
}
|
|
|
|
|
|
$in_info= InvalidT::findOne(['id'=>$invalid_id]);
|
|
$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 = date("Y-m-d",strtotime("+1 day"));
|
|
$row->ptime = '09:00';
|
|
$row->ptype = 0;
|
|
$row->remark =$in_info->name ;
|
|
$row->business_group_id = 0;
|
|
$row->yuyue_num = $row->yuyue_num+1;
|
|
$row->is_first = 0;
|
|
$row->save();
|
|
|
|
|
|
|
|
$log_txt = '';
|
|
if($old_user_id > 0) {
|
|
$log_txt = '旧业务员是:'.$old_user_id.' ';
|
|
}
|
|
$this->addLog($car_id,$log_txt.'预约客户到'. date("Y-m-d",strtotime("+1 day")).' 09:00 预约内容为:'.$in_info->name,1);
|
|
|
|
if($row && $row->yuyue_num==4){ //进入无效库
|
|
$car_info->location = 16;
|
|
CarMistakeT::deleteAll('id='.$car_info->id);
|
|
$invalid_info = new CarMistakeT();
|
|
$invalid_info->id = $car_info->id;
|
|
$invalid_info->invalid_id = $invalid_id;
|
|
$invalid_info->user_id = $this->my->id;
|
|
if($clean_info->repeat==1){
|
|
$invalid_info->judge = 1;
|
|
}else{
|
|
$invalid_info->judge = 2;
|
|
}
|
|
$invalid_info->user_id = $this->my->id;
|
|
$invalid_info->save();
|
|
$car_info->save();
|
|
$this->addLog($car_info->id,'不准确车辆数据:'.$invalid_info->invalid->name,1);
|
|
CarBT::deleteAll(['id'=>$car_info->id]);
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
CarDT::deleteAll(['id'=>$car_info->id]);
|
|
CarET::deleteAll(['id'=>$car_info->id]);
|
|
CleanT::deleteAll(['id'=>$car_info->id]);
|
|
$cleantj= new CleanTongji();
|
|
$cleantj->user_id=$this->my->id;
|
|
$cleantj->wrong_num=1;
|
|
$cleantj->yuefen=date('Y-m-d');
|
|
$cleantj->car_id=$car_info->id;
|
|
$cleantj->car_no=$car_info->car_no;
|
|
$cleantj->save();
|
|
|
|
//删除预约
|
|
FiltrationT::deleteAll('car_id='.$car_info->id);
|
|
}
|
|
|
|
|
|
}elseif($invalid_id>68 && $invalid_id<76){ //不准确
|
|
$car_info->location = 16;
|
|
CarMistakeT::deleteAll('id='.$car_info->id);
|
|
$invalid_info = new CarMistakeT();
|
|
$invalid_info->id = $car_info->id;
|
|
$invalid_info->invalid_id = $invalid_id;
|
|
$invalid_info->user_id = $this->my->id;
|
|
if($clean_info->repeat==1){
|
|
$invalid_info->judge = 1;
|
|
}else{
|
|
$invalid_info->judge = 2;
|
|
}
|
|
$invalid_info->user_id = $this->my->id;
|
|
$invalid_info->save();
|
|
$car_info->save();
|
|
$this->addLog($car_info->id,'不准确车辆数据:'.$invalid_info->invalid->name,1);
|
|
CarBT::deleteAll(['id'=>$car_info->id]);
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
CarDT::deleteAll(['id'=>$car_info->id]);
|
|
CarET::deleteAll(['id'=>$car_info->id]);
|
|
CleanT::deleteAll(['id'=>$car_info->id]);
|
|
$cleantj= new CleanTongji();
|
|
$cleantj->user_id=$this->my->id;
|
|
$cleantj->wrong_num=1;
|
|
$cleantj->yuefen=date('Y-m-d');
|
|
$cleantj->car_id=$car_info->id;
|
|
$cleantj->car_no=$car_info->car_no;
|
|
$cleantj->save();
|
|
|
|
//删除预约
|
|
FiltrationT::deleteAll('car_id='.$car_info->id);
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
private function getMistakeQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
$invalid_id = $request->post('invalid_id');
|
|
$username = $request->post('username');
|
|
$user1 = $request->post('user1');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$judge = $request->post('judge');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$register_begin = $request->get('register_begin');
|
|
$register_end = $request->get('register_end');
|
|
$insurer1_begin = $request->get('insurer1_begin');
|
|
$insurer1_end = $request->get('insurer1_end');
|
|
$invalid_id = $request->get('invalid_id');
|
|
$username = $request->get('username');
|
|
$user1 = $request->get('user1');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$judge = $request->get('judge');
|
|
}
|
|
$params = array();
|
|
$params['car_man'] = $car_man;
|
|
$params['phone'] = $phone;
|
|
$params['car_no'] = $car_no;
|
|
$params['register_begin'] = $register_begin;
|
|
$params['register_end'] = $register_end;
|
|
$params['insurer1_begin'] = $insurer1_begin;
|
|
$params['insurer1_end'] = $insurer1_end;
|
|
$params['invalid_id'] = $invalid_id;
|
|
$params['username'] = $username;
|
|
$params['user1'] = $user1;
|
|
$params['sort_key'] = $sort_key;
|
|
$params['sort_value'] = $sort_value;
|
|
$params['judge'] = $judge;
|
|
|
|
$query = CarMistakeT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_mistake_t`.`id`');
|
|
|
|
if($car_man != '') {
|
|
$query = $query->andWhere('car_t.car_man="'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query = $query->andWhere('car_t.phone="'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
$query = $query->andWhere('car_t.car_no="'.$car_no.'"');
|
|
}
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($invalid_id > 0) {
|
|
$query = $query->andWhere('car_mistake_t.invalid_id='.$invalid_id);
|
|
}
|
|
if($judge > 0) {
|
|
$query = $query->andWhere(['judge'=>$judge]);
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('car_t.op_user1 like "'.$user1.'%"');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_mistake_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.',car_mistake_t.id '.$sort_value);
|
|
// echo $query->createCommand()->rawSql;
|
|
return ['query'=>$query,'params'=>$params];
|
|
}
|
|
public function actionMistakeIndex()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
$data = $this->getMistakeQuery($request);
|
|
$query = $data['query'];
|
|
$params = $data['params'];
|
|
$params['page'] = $page;
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_mistake_t.id=-1');
|
|
}
|
|
// 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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTreeClean(2);
|
|
|
|
$params['items'] = $items;
|
|
$params['page_info'] = $page_info;
|
|
$params['invalid_items'] = $invalid_items;
|
|
|
|
return $this->render('mistake-index',$params);
|
|
}
|
|
public function actionMistakeOutput()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page', 1);
|
|
|
|
|
|
$data = $this->getMistakeQuery($request);
|
|
$query = $data['query'];
|
|
$params = $data['params'];
|
|
$params['page'] = $page;
|
|
|
|
|
|
|
|
// var_dump($group_ids);
|
|
|
|
if ($page < 1) $page = 1;
|
|
$items = $query->all();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$objectPHPExcel = new \PHPExcel();
|
|
$index = 1;
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('A'.$index,'车牌号');
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('B'.$index,'车架号');
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('C'.$index,'发动机号');
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('D'.$index,'身份证号');
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('E'.$index,'姓名');
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('F'.$index,'初登日期');
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('G'.$index,'保险日期');
|
|
|
|
|
|
|
|
|
|
foreach($query->each() as $item) {
|
|
$index++;
|
|
$car_info = $item->car;
|
|
|
|
|
|
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('A'.$index,$car_info->car_no);
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('B'.$index,$car_info->car_frame_no);
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('C'.$index,$car_info->engine_no);
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('D'.$index,$car_info->id_number);
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('E'.$index,$car_info->id_man);
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('F'.$index,$car_info->register_date);
|
|
$objectPHPExcel->setActiveSheetIndex(0)->setCellValue('G'.$index,$car_info->insurer1_date);
|
|
// ;
|
|
}
|
|
|
|
header('Content-Type: application/vnd.ms-excel;charset=utf-8');
|
|
header('Content-Disposition:attachment;filename="'.date("YmjHis").'.xls"');
|
|
header('Cache-Control: max-age=0');
|
|
$objWriter = \PHPExcel_IOFactory::createWriter($objectPHPExcel, 'Excel5');
|
|
$objWriter->save('php://output');
|
|
foreach($query->each() as $item) {
|
|
$item->delete();
|
|
}
|
|
|
|
|
|
}
|
|
public function actionInvalid()
|
|
{
|
|
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());
|
|
$invalid_id = $request->post('invalid_id',0);
|
|
|
|
if($invalid_id == 0) {
|
|
$result['msg'] = '请先选择无效理由';
|
|
return $result;
|
|
}
|
|
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 = 5;
|
|
$car_info->save();
|
|
|
|
CarInvalidT::deleteAll('id='.$car_info->id);
|
|
$invalid_info = new CarInvalidT();
|
|
$invalid_info->id = $car_info->id;
|
|
$invalid_info->invalid_id = $invalid_id;
|
|
$invalid_info->user_id = $this->my->id;
|
|
$invalid_info->save();
|
|
|
|
CarBT::deleteAll(['id'=>$car_info->id]);
|
|
CarCT::deleteAll(['id'=>$car_info->id]);
|
|
CarDT::deleteAll(['id'=>$car_info->id]);
|
|
CarET::deleteAll(['id'=>$car_info->id]);
|
|
|
|
//删除预约
|
|
AppointmentT::deleteAll('car_id='.$car_info->id);
|
|
|
|
//删除操作人员
|
|
$orders = OrderT::find()
|
|
->where('car_id='.$car_info->id.' and status_id<2')
|
|
->all();
|
|
foreach($orders as $order_info) {
|
|
OrderUserT::deleteAll('order_id='.$order_info->id);
|
|
//删除保单
|
|
$order_info->delete();
|
|
}
|
|
|
|
$this->addLog($car_info->id,'无效车辆数据:'.$invalid_info->invalid->name,1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionAMoveB()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
$flag = 0;
|
|
if($request->isPost) {
|
|
$unsel_lib = $request->post('unsel_lib',0);
|
|
$has_phone = $request->post('has_phone');
|
|
$data = $this->getAQuery($request);
|
|
$query = $data['query'];
|
|
|
|
if($unsel_lib == 0) {
|
|
$result['msg'] = '请先选择未分配选项';
|
|
return $result;
|
|
}
|
|
if($has_phone != 1) {
|
|
$result['msg'] = '请先选择有电话号码选项';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $car_info) {
|
|
if($car_info->location == 1) {
|
|
if($car_info->qiyong==2){
|
|
continue;
|
|
}
|
|
$car_info->location = 2;
|
|
$car_info->save();
|
|
|
|
$b_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$b_info) {
|
|
$b_info = new CarBT();
|
|
$b_info->id = $car_info->id;
|
|
$b_info->user_id = 0;
|
|
$b_info->save();
|
|
|
|
$this->addLog($car_info->id,'从A库分配到B库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionAMoveE()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
$flag = 0;
|
|
if($request->isPost) {
|
|
$unsel_lib = $request->post('unsel_lib',0);
|
|
$has_phone = $request->post('has_phone');
|
|
$data = $this->getAQuery($request);
|
|
$query = $data['query'];
|
|
|
|
if($unsel_lib == 0) {
|
|
$result['msg'] = '请先选择未分配选项';
|
|
return $result;
|
|
}
|
|
if($has_phone != 1) {
|
|
$result['msg'] = '请先选择有电话号码选项';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $car_info) {
|
|
if($car_info->location == 1) {
|
|
if($car_info->qiyong==2){
|
|
continue;
|
|
}
|
|
$car_info->location = 6;
|
|
$car_info->save();
|
|
|
|
$b_info = CarET::findOne(['id'=>$car_info->id]);
|
|
if(!$b_info) {
|
|
$b_info = new CarET();
|
|
$b_info->id = $car_info->id;
|
|
$b_info->user_id = 0;
|
|
$b_info->save();
|
|
|
|
$this->addLog($car_info->id,'从A库分配到E库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionAMoveClean()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
$flag = 0;
|
|
if($request->isPost) {
|
|
$unsel_lib = $request->post('unsel_lib',0);
|
|
$has_phone = $request->post('has_phone');
|
|
$data = $this->getAQuery($request);
|
|
$query = $data['query'];
|
|
|
|
if($unsel_lib == 0) {
|
|
$result['msg'] = '请先选择未分配选项';
|
|
return $result;
|
|
}
|
|
if($has_phone != 1) {
|
|
$result['msg'] = '请先选择有电话号码选项';
|
|
return $result;
|
|
}
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $car_info) {
|
|
if($car_info->location == 1) {
|
|
if($car_info->qiyong==2){
|
|
continue;
|
|
}
|
|
$car_info->location =14;
|
|
$car_info->save();
|
|
|
|
$b_info = CleanT::findOne(['id'=>$car_info->id]);
|
|
if(!$b_info) {
|
|
$b_info = new CleanT();
|
|
$b_info->id = $car_info->id;
|
|
$b_info->user_id = 0;
|
|
|
|
if($b_info->save()){
|
|
$fenpei= new CleanFenpei();
|
|
$fenpei->user_id=$this->my->id;
|
|
$fenpei->fenpei_num=1;
|
|
$fenpei->fenpei_date=date('Y-m-d');
|
|
$fenpei->save();
|
|
}
|
|
|
|
$this->addLog($car_info->id,'从A库分配到清洗库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
private function getBQuery1($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->post('insurer1_day');
|
|
$insurer1_month1 = $request->post('insurer1_date1');
|
|
$insurer1_day1 = $request->post('insurer1_day1');
|
|
$username = $request->post('username');
|
|
$status = $request->post('status');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$company = $request->post('company');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$company = $request->get('company');
|
|
}
|
|
$query = CarBT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_b_t`.`id`')
|
|
->andWhere('car_b_t.back =1');
|
|
|
|
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 != '') {
|
|
if($car_no == '非京'){
|
|
$query = $query->andWhere('car_no not like "京%"');
|
|
}else{
|
|
$query = $query->andWhere('car_no like "'.$car_no.'%"');
|
|
}
|
|
}
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_b_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_b_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_b_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_b_t.id '.$sort_value);
|
|
// echo $query->createCommand()->rawSql;
|
|
// exit;
|
|
return $query;
|
|
}
|
|
//数据准确库
|
|
private function getRightQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->post('insurer1_day');
|
|
$insurer1_month1 = $request->post('insurer1_date1');
|
|
$insurer1_day1 = $request->post('insurer1_day1');
|
|
$username = $request->post('username');
|
|
$status = $request->post('status');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$company = $request->post('company');
|
|
$judge = $request->post('judge');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$company = $request->get('company');
|
|
$judge = $request->get('judge');
|
|
}
|
|
$query = RightT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`right_t`.`id`');
|
|
|
|
|
|
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 != '') {
|
|
if($car_no == '非京'){
|
|
$query = $query->andWhere('car_no not like "京%"');
|
|
}else{
|
|
$query = $query->andWhere('car_no like "'.$car_no.'%"');
|
|
}
|
|
}
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
if($status == 1) {
|
|
$query = $query->andWhere('right_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('right_t.user_id>0');
|
|
}
|
|
if($judge > 0) {
|
|
$query = $query->andWhere(['judge'=>$judge]);
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_b_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', right_t.id '.$sort_value);
|
|
// dd(32);
|
|
// echo $query->createCommand()->rawSql;
|
|
// exit;
|
|
return $query;
|
|
}
|
|
public function actionRightIndex()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status',1);
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$company = $request->get('company');
|
|
$judge = $request->get('judge');
|
|
|
|
$query = $this->getRightQuery($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('right_t.id=-1');
|
|
}
|
|
// 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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
|
|
return $this->render('right-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'user_id' => $user_id,
|
|
'status' => $status,
|
|
'judge' => $judge,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'company' => $company,
|
|
]);
|
|
}
|
|
public function actionAjaxAReturn()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
$id = $request->post('id',0);
|
|
//没有任务
|
|
// ->andWhere(['repeat'=>1])
|
|
|
|
//echo $id;die;
|
|
// dd($id);
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
$car_info = CarT::findOne($id);
|
|
// $car_info->location = 14;
|
|
|
|
|
|
$c_info = CleanT::findOne(['id'=>$car_info->id]);
|
|
if($c_info) {
|
|
$c_info->user_id = 0;
|
|
$c_info->save();
|
|
}
|
|
|
|
// FiltrationT
|
|
//删除预约拨打
|
|
FiltrationT::deleteAll('car_id='.$c_info->id);
|
|
|
|
$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 actionAjaxAData()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$result['success'] = false;
|
|
$result['msg'] = '领取失败';
|
|
//没有任务
|
|
// ->andWhere(['repeat'=>1])
|
|
$total_ids= CleanT::find()->where('user_id=0')->column();
|
|
|
|
// $total_ids = OrderT::find()->andWhere('status_id=2 and hb_status=0 and lock_id=0 and (op1_id=0 or op1_id is NULL) ')->column();
|
|
$count = count($total_ids);
|
|
if($count<1){
|
|
$result['msg'] = '没有任务';
|
|
return $result;
|
|
}
|
|
// dd($total_ids);
|
|
$i = rand(0,$count-1);
|
|
$id = $total_ids[$i];
|
|
//echo $id;die;
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
$car_info = CarT::findOne($id);
|
|
// $car_info->location = 14;
|
|
if($car_info->save()){
|
|
|
|
//取出上一条判断状态
|
|
$clean_count= CleanT::find()
|
|
->where(['user_id'=>$this->my->id])
|
|
->andWhere(['lingqu_status'=>1])
|
|
->count();
|
|
$clean_count=(int)$clean_count;
|
|
if($clean_count>0){
|
|
$result['msg'] = '上一条数据未处理不能领取任务';
|
|
return $result;
|
|
|
|
}
|
|
$c_info = CleanT::findOne(['id'=>$car_info->id]);
|
|
if(!$c_info) {
|
|
$c_info = new CleanT();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = $this->my->id;
|
|
}else{
|
|
$c_info->user_id = $this->my->id;
|
|
}
|
|
$c_info->now_time=new Expression('NOW()');
|
|
$c_info->save();
|
|
// FiltrationT
|
|
//添加到预约拨打
|
|
$filt=FiltrationT::findOne(['car_id'=>$c_info->id]);
|
|
if($filt){
|
|
$filt->user_id = $this->my->id;
|
|
$filt->delete_status=1;
|
|
$filt->save();
|
|
|
|
}else{
|
|
$row = new FiltrationT();
|
|
$row->car_id = $c_info->id;
|
|
$row->user_id = $this->my->id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
$row->save();
|
|
}
|
|
// FiltrationT::deleteAll('car_id='.$c_info->id);
|
|
|
|
$this->addLog($car_info->id,'从A库领取一条数据成功',1);
|
|
$result['success'] = true;
|
|
$result['msg'] = '领取成功';
|
|
}
|
|
$tran->commit();
|
|
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
}
|
|
|
|
public function actionAjaxADataNext()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$result['success'] = false;
|
|
$result['msg'] = '领取失败';
|
|
//没有任务
|
|
// ->andWhere(['repeat'=>1])
|
|
$total_ids= CleanT::find()->where('user_id=0')->column();
|
|
|
|
// $total_ids = OrderT::find()->andWhere('status_id=2 and hb_status=0 and lock_id=0 and (op1_id=0 or op1_id is NULL) ')->column();
|
|
$count = count($total_ids);
|
|
if($count<1){
|
|
$result['msg'] = '没有任务';
|
|
return $result;
|
|
}
|
|
|
|
$i = rand(0,$count-1);
|
|
$id = $total_ids[$i];
|
|
//echo $id;die;
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
$car_info = CarT::findOne($id);
|
|
// $car_info->location = 14;
|
|
$clean_count= CleanT::find()
|
|
->where(['user_id'=>$this->my->id])
|
|
->andWhere(['lingqu_status'=>1])
|
|
->count();
|
|
$clean_count=(int)$clean_count;
|
|
if($clean_count>0){
|
|
$result['msg'] = '有未处理的数据不能自动进入下一条';
|
|
return $result;
|
|
|
|
}
|
|
if($car_info->save()){
|
|
|
|
$c_info = CleanT::findOne(['id'=>$car_info->id]);
|
|
if(!$c_info) {
|
|
$c_info = new CleanT();
|
|
$c_info->id = $car_info->id;
|
|
$c_info->user_id = $this->my->id;
|
|
}else{
|
|
$c_info->user_id = $this->my->id;
|
|
}
|
|
$c_info->now_time=new Expression('NOW()');
|
|
$c_info->save();
|
|
// FiltrationT
|
|
//添加到预约拨打
|
|
// FiltrationT::deleteAll('car_id='.$c_info->id);
|
|
// $row = new FiltrationT();
|
|
// $row->car_id = $c_info->id;
|
|
// $row->user_id = $this->my->id;
|
|
// $row->pdate = date('Y-m-d');
|
|
// $row->ptime = '09:00';
|
|
// $row->remark = '首次分配';
|
|
// $row->is_first = 1;
|
|
// $row->xdate = date('Y-m-d');
|
|
// $row->xtime = '09:00';
|
|
// $row->xbao = 2;
|
|
// $row->save();
|
|
|
|
$filt=FiltrationT::findOne(['car_id'=>$c_info->id]);
|
|
if($filt){
|
|
$filt->user_id = $this->my->id;
|
|
$filt->delete_status=1;
|
|
$filt->save();
|
|
|
|
}else{
|
|
$row = new FiltrationT();
|
|
$row->car_id = $c_info->id;
|
|
$row->user_id = $this->my->id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
$row->save();
|
|
}
|
|
$this->addLog($car_info->id,'从A库领取一条数据成功',1);
|
|
$result['success'] = true;
|
|
$result['data'] = $car_info->id;
|
|
$result['msg'] = '领取成功';
|
|
}
|
|
$tran->commit();
|
|
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
}
|
|
public function actionCleanToRight()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$result['success'] = false;
|
|
$result['msg'] = '领取失败';
|
|
$request = Yii::$app->request;
|
|
$id=$request->post('car_id');
|
|
// dd($id);
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
if ($request->isPost) {
|
|
|
|
$car_info = CarT::findOne($id);
|
|
$car_info->location = 15;
|
|
$car_info->save();
|
|
$clean_info=CleanT::findOne(['id'=>$id]);
|
|
$c_info = RightT::findOne(['id' => $car_info->id]);
|
|
if (!$c_info) {
|
|
$c_info = new RightT();
|
|
$c_info->id = $car_info->id;
|
|
if($clean_info->repeat==1){
|
|
$c_info->judge = 1;
|
|
}else{
|
|
$c_info->judge = 2;
|
|
}
|
|
$c_info->user_id = 0;
|
|
$c_info->caozuo_id = $this->my->id;
|
|
$c_info->save();
|
|
|
|
}
|
|
|
|
CleanT::deleteAll(['id' => $car_info->id]);
|
|
$cleantj= new CleanTongji();
|
|
$cleantj->user_id=$this->my->id;
|
|
$cleantj->right_num=1;
|
|
$cleantj->yuefen=date('Y-m-d');
|
|
$cleantj->car_id=$car_info->id;
|
|
$cleantj->car_no=$car_info->car_no;
|
|
$cleantj->save();
|
|
|
|
|
|
$this->addLog($car_info->id, '从清洗库分配到数据准确库成功', 1);
|
|
$result['success'] = true;
|
|
$result['msg'] = '分配成功';
|
|
|
|
$tran->commit();
|
|
}
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
|
|
}
|
|
|
|
|
|
return $result;
|
|
}
|
|
private function getcleanQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->post('insurer1_day');
|
|
$insurer1_month1 = $request->post('insurer1_date1');
|
|
$insurer1_day1 = $request->post('insurer1_day1');
|
|
$username = $request->post('username');
|
|
$status = $request->post('status');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$company = $request->post('company');
|
|
$repeat = $request->post('repeat');
|
|
$yuyue = $request->post('yuyue');
|
|
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status');
|
|
$repeat = $request->get('repeat');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$company = $request->get('company');
|
|
$yuyue = $request->get('yuyue');
|
|
}
|
|
$query = CleanT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`clean_t`.`id`');
|
|
|
|
|
|
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 != '') {
|
|
if($car_no == '非京'){
|
|
$query = $query->andWhere('car_no not like "京%"');
|
|
}else{
|
|
$query = $query->andWhere('car_no like "'.$car_no.'%"');
|
|
}
|
|
}
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
// }
|
|
|
|
|
|
if($status == 1) {
|
|
$query = $query->andWhere('clean_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('clean_t.user_id>0');
|
|
}
|
|
$query = $query->andWhere(['yuyue'=>1]);
|
|
// if($yuyue>0){
|
|
// $query = $query->andWhere(['yuyue'=>$yuyue]);
|
|
// }
|
|
if($repeat>0){
|
|
$query = $query->andWhere(['repeat'=>$repeat]);
|
|
}
|
|
// if($username != '') {
|
|
// $user_info = UserT::findOne(['username'=>$username]);
|
|
// if($user_info) {
|
|
// $query = $query->andWhere('clean_t.user_id='.$user_info->id);
|
|
// }
|
|
// }
|
|
if($username == '') {
|
|
$user_ids = $this->getChildrenUserIDs();
|
|
$query = $query->andWhere(['in','clean_t.user_id',$user_ids]);
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', clean_t.id '.$sort_value);
|
|
echo $query->createCommand()->rawSql;
|
|
// exit;
|
|
return $query;
|
|
}
|
|
public function actionCleanIndex()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status',2);
|
|
$repeat = $request->get('repeat',1);
|
|
$yuyue = $request->get('yuyue',1);
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$company = $request->get('company');
|
|
|
|
$query = $this->getcleanQuery($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('clean_t.id=-1');
|
|
}
|
|
// 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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
$carAcount=CleanT::find()->where('user_id=0')->count();
|
|
|
|
return $this->render('clean-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'user_id' => $user_id,
|
|
'status' => $status,
|
|
'repeat' => $repeat,
|
|
'yuyue' => $yuyue,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'company' => $company,
|
|
'carAcount' => $carAcount,
|
|
]);
|
|
}
|
|
|
|
public function actionBAllAssign1()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$assign_users = explode(',',$request->post('assign_users'));
|
|
$assign_count = $request->post('assign_count',0);
|
|
$assign_user_ids = array();
|
|
foreach($assign_users as $assign_user) {
|
|
$user_info = UserT::findOne(['username'=>$assign_user,'is_delete'=>0]);
|
|
if($user_info)
|
|
$assign_user_ids[] = $user_info->id;
|
|
}
|
|
if(count($assign_user_ids) == 0) {
|
|
$result['msg'] = '请输入业务员工号,以英文逗号间隔';
|
|
return $result;
|
|
}
|
|
if($assign_count == 0) {
|
|
$result['msg'] = '请输入每个业务员分配记录数';
|
|
return $result;
|
|
}
|
|
|
|
$query = $this->getBQuery1($request);
|
|
// echo $query->createCommand()->rawSql;
|
|
// echo $query->count();
|
|
// exit;
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
$page = 0;
|
|
$total_pages = count($assign_user_ids);
|
|
$index = 0;
|
|
foreach($query->each(100) as $b_info) {
|
|
if($index >= ($page+1) * $assign_count) $page += 1;
|
|
if($page == $total_pages) break;
|
|
if($b_info->user_id > 0) continue;
|
|
$b_info->user_id = $assign_user_ids[$page];
|
|
$b_info->save();
|
|
|
|
$car_info = $b_info->car;
|
|
$car_info->op_user1 = $b_info->user->getShowName();
|
|
$car_info->save();
|
|
|
|
//添加保单
|
|
$order_row = new OrderT();
|
|
$order_row->car_id = $b_info->id;
|
|
$order_row->car_no = $b_info->car->car_no;
|
|
$order_row->engine_no = $b_info->car->engine_no;
|
|
$order_row->car_frame_no = $b_info->car->car_frame_no;
|
|
$order_row->car_man = $b_info->car->car_man;
|
|
$order_row->user_id = $b_info->user_id;
|
|
$order_row->status_id = 1;
|
|
$order_row->id_man = $b_info->car->car_man;
|
|
$order_row->link_man = $b_info->car->car_man;
|
|
$order_row->link_phone = $b_info->car->phone;
|
|
$order_row->return_status_id = 0;
|
|
$order_row->return_remark = '';
|
|
$order_row->save();
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$b_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $b_info->id;
|
|
$row->user_id = $b_info->user_id;
|
|
$row->pdate = date('Y-m-d');
|
|
$row->ptime = '09:00';
|
|
$row->remark = '首次分配';
|
|
$row->is_first = 1;
|
|
$row->xdate = date('Y-m-d');
|
|
$row->xtime = '09:00';
|
|
$row->xbao = 2;
|
|
$row->save();
|
|
|
|
//添加历史预约
|
|
$h_row = new AppointmentHistoryT();
|
|
$h_row->car_id = $b_info->id;
|
|
$h_row->user_id = $b_info->user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptime = '09:00';
|
|
$h_row->remark = '首次分配';
|
|
$h_row->xdate = date('Y-m-d');
|
|
$h_row->xtime = '09:00';
|
|
$h_row->xbao = 2;
|
|
$h_row->save();
|
|
|
|
$this->addLog($b_info->id,'从B库的数据管理分支分配数据给业务员:'.$b_info->user->getShowName(),1);
|
|
$index++;
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionBReturnAllWuxiao()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
|
|
|
|
$status = $request->post('status');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
$invalid_id = $request->post('invalid_id');
|
|
|
|
if($status!=1){
|
|
$result['msg'] = '请选择未分配状态';
|
|
return $result;
|
|
}
|
|
|
|
|
|
$query = CarBT::find()
|
|
->leftJoin('car_t','`car_t`.`id`=`car_b_t`.`id`')
|
|
->andWhere('car_b_t.back=1');
|
|
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_b_t.user_id=0');
|
|
}
|
|
if($invalid_id >0) {
|
|
$query = $query->andWhere('car_b_t.iv_d="'.$invalid_id.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
|
|
|
|
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
$car_info = $item->car;
|
|
$car_info->location = 5;
|
|
$car_info->save();
|
|
|
|
// FiltrationT
|
|
//删除预约拨打
|
|
// FiltrationT::deleteAll('car_id='.$c_info->id);
|
|
CarInvalidT::deleteAll('id='.$car_info->id);
|
|
InvalidNew::deleteAll('car_id='.$car_info->id);
|
|
|
|
|
|
$invalid_info = new CarInvalidT();
|
|
$invalid_info->id = $car_info->id;
|
|
$invalid_info->invalid_id = $item->iv_d;
|
|
$invalid_info->user_id = $this->my->id;
|
|
$invalid_info->save();
|
|
|
|
|
|
$this->addLog($item->id,'从B库新保数据处理批量收回到无效库',1);
|
|
$item->delete();
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionCleanReturnA()
|
|
{
|
|
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) {
|
|
$b_info = CleanT::findOne(['id'=>$id]);
|
|
//删除预约
|
|
FiltrationT::deleteAll('car_id='.$b_info->id);
|
|
$car_info = $b_info->car;
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
$this->addLog($b_info->id,'从清洗库回收数据到A库',1);
|
|
$b_info->delete();
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionCleanReturnAllA()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
|
|
$yuyue = $request->post('yuyue');
|
|
$status = $request->post('status');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
|
|
if($yuyue!=1 || $status!=1){
|
|
$result['msg'] = '请选择未预约状态或未分配状态';
|
|
return $result;
|
|
}
|
|
|
|
|
|
$query = CleanT::find()
|
|
->leftJoin('car_t','`car_t`.`id`=`clean_t`.`id`')
|
|
->andWhere(['yuyue'=>$yuyue])
|
|
->andWhere('clean_t.user_id=0');
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
|
|
|
|
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(1000) as $item) {
|
|
$car_info = $item->car;
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
$item->delete();
|
|
// FiltrationT
|
|
//删除预约拨打
|
|
// FiltrationT::deleteAll('car_id='.$c_info->id);
|
|
$this->addLog($item->id,'从清洗库数据未领取的任务收回到A库',1);
|
|
}
|
|
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
throw $e;
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
private function getEQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$print_begin = $request->post('print_begin');
|
|
$print_end = $request->post('print_end');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$company = $request->post('company');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_end');
|
|
$insurer1_begin = $request->get('insurer1_begin');
|
|
$insurer1_end = $request->get('insurer1_end');
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$company = $request->get('company');
|
|
$register_begin = $request->get('register_begin');
|
|
$register_end = $request->get('register_end');
|
|
}
|
|
$query = CarET::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_e_t`.`id`');
|
|
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($print_begin != '') {
|
|
$query = $query->andWhere('car_t.print_date>="'.$print_begin.'"');
|
|
}
|
|
if($print_end != '') {
|
|
$query = $query->andWhere('car_t.print_date<="'.$print_end.'"');
|
|
}
|
|
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.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_e_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_e_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
// $user_info = UserT::findOne(['username'=>$username]);
|
|
// $query = $query->andWhere('op_user1 like "'.$user1.'%"');
|
|
$user_info = UserT::find()->where('username like"'.$username.'%"')->all();
|
|
// $user_ids='';
|
|
$user_ids = array();
|
|
if($user_info){
|
|
foreach($user_info as $v){
|
|
// $user_ids.="'".$v->id."'".',';
|
|
// var_dump($v->id);
|
|
$user_ids[] = $v->username.'('.$v->name.')';
|
|
}
|
|
}
|
|
|
|
// var_dump($user_ids);
|
|
//
|
|
// $srrs=trim($user_ids,',');
|
|
// var_dump($srrs);
|
|
// var_dump('car_e_t.user_id in ('.$srrs.')');
|
|
if($user_info) {
|
|
$query = $query->andWhere(['in','car_t.op_user1',$user_ids]);
|
|
}
|
|
}
|
|
// $query = $query->andWhere(['in','car_t.op_user1',$user_ids]);
|
|
if($old_user != '') {
|
|
$query = $query->andWhere('car_t.old_user="'.$old_user.'"');
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company="'.$company.'"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_e_t.id '.$sort_value);
|
|
return $query;
|
|
}
|
|
|
|
private function getAdCleanQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->post('insurer1_day');
|
|
$insurer1_month1 = $request->post('insurer1_date1');
|
|
$insurer1_day1 = $request->post('insurer1_day1');
|
|
$username = $request->post('username');
|
|
$status = $request->post('status');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$company = $request->post('company');
|
|
$repeat = $request->post('repeat');
|
|
$yuyue = $request->post('yuyue');
|
|
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status');
|
|
$repeat = $request->get('repeat');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$company = $request->get('company');
|
|
$yuyue = $request->get('yuyue');
|
|
}
|
|
$query = CleanT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`clean_t`.`id`');
|
|
|
|
|
|
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 != '') {
|
|
if($car_no == '非京'){
|
|
$query = $query->andWhere('car_no not like "京%"');
|
|
}else{
|
|
$query = $query->andWhere('car_no like "'.$car_no.'%"');
|
|
}
|
|
}
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
if($repeat>0){
|
|
$query = $query->andWhere(['repeat'=>$repeat]);
|
|
}
|
|
// if($username != '') {
|
|
// $user_info = UserT::findOne(['username'=>$username]);
|
|
// if($user_info) {
|
|
// $query = $query->andWhere('clean_t.user_id='.$user_info->id);
|
|
// }
|
|
// }
|
|
|
|
if($yuyue>0){
|
|
$query = $query->andWhere(['yuyue'=>$yuyue]);
|
|
}
|
|
|
|
//采用这个
|
|
if($status==1){ //未分配
|
|
$query = $query->andWhere('clean_t.user_id=0');
|
|
}
|
|
if($status==2){
|
|
$query = $query->andWhere('clean_t.user_id>0'); //已分配
|
|
if($username == '') {
|
|
$user_ids = $this->getChildrenUserIDs();
|
|
$query = $query->andWhere(['in','clean_t.user_id',$user_ids]);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
//
|
|
// $query = $query->andWhere('clean_t.user_id= 0');
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', clean_t.id '.$sort_value);
|
|
// echo $query->createCommand()->rawSql;
|
|
// exit;
|
|
return $query;
|
|
}
|
|
public function actionAdCleanIndex()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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_date');
|
|
$insurer1_day = $request->get('insurer1_day');
|
|
$insurer1_month1 = $request->get('insurer1_date1');
|
|
$insurer1_day1 = $request->get('insurer1_day1');
|
|
$username = $request->get('username');
|
|
$status = $request->get('status',1);
|
|
$repeat = $request->get('repeat',1);
|
|
$yuyue = $request->get('yuyue',1);
|
|
// echo $yuyue;
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
// dd($user_id);
|
|
$company = $request->get('company');
|
|
|
|
$query = $this->getAdCleanQuery($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('clean_t.id=-1');
|
|
}
|
|
// 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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
$carAcount=CleanT::find()->where('user_id=0')->count();
|
|
// $cfor=CleanT::find();
|
|
// foreach($cfor->each(1) as $c){
|
|
//
|
|
// $c->now_time=new Expression('NOW()');
|
|
// $c->save();
|
|
//
|
|
// }
|
|
$role_id=$this->my->role_id;
|
|
return $this->render('ad-clean-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'user_id' => $user_id,
|
|
'status' => $status,
|
|
'repeat' => $repeat,
|
|
'yuyue' => $yuyue,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'company' => $company,
|
|
'role_id' => $role_id,
|
|
'carAcount' => $carAcount,
|
|
]);
|
|
}
|
|
|
|
public function actionEIndex()
|
|
{
|
|
|
|
$request = Yii::$app->request;
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$engine_no = $request->get('engine_no');
|
|
$car_frame_no = $request->get('car_frame_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_end');
|
|
$insurer1_begin = $request->get('insurer1_begin');
|
|
$insurer1_end = $request->get('insurer1_end');
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
$company = $request->get('company');
|
|
$register_begin = $request->get('register_begin');
|
|
$register_end = $request->get('register_end');
|
|
$query = $this->getEQuery($request);
|
|
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_e_t.id=-1');
|
|
}
|
|
// 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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
|
|
return $this->render('e-index',[
|
|
'items' => $items,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'engine_no' => $engine_no,
|
|
'car_frame_no' => $car_frame_no,
|
|
'print_begin' => $print_begin,
|
|
'print_end' => $print_end,
|
|
'register_begin' => $register_begin,
|
|
'register_end' => $register_end,
|
|
'insurer1_begin' => $insurer1_begin,
|
|
'insurer1_end' => $insurer1_end,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'status' => $status,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'user_id' => $user_id,
|
|
'company' => $company
|
|
]);
|
|
}
|
|
|
|
|
|
public function actionEAllAssign()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$assign_users = explode(',',$request->post('assign_users'));
|
|
$assign_count = $request->post('assign_count',0);
|
|
$assign_user_ids = array();
|
|
foreach($assign_users as $assign_user) {
|
|
$user_info = UserT::findOne(['username'=>$assign_user]);
|
|
if($user_info)
|
|
$assign_user_ids[] = $user_info->id;
|
|
}
|
|
if(count($assign_user_ids) == 0) {
|
|
$result['msg'] = '请输入业务员工号,以英文逗号间隔';
|
|
return $result;
|
|
}
|
|
if($assign_count == 0) {
|
|
$result['msg'] = '请输入每个业务员分配记录数';
|
|
return $result;
|
|
}
|
|
|
|
$query = $this->getEQuery($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
$page = 0;
|
|
$total_pages = count($assign_user_ids);
|
|
$index = 0;
|
|
foreach($query->each(100) as $c_info) {
|
|
if($index >= ($page+1) * $assign_count) $page += 1;
|
|
if($page == $total_pages) break;
|
|
if($c_info->user_id > 0) continue;
|
|
$c_info->user_id = $assign_user_ids[$page];
|
|
$c_info->save();
|
|
|
|
$car_info = $c_info->car;
|
|
$car_info->op_user2 = $c_info->user->getShowName();
|
|
$car_info->save();
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$c_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $c_info->id;
|
|
$row->user_id = $c_info->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 = $c_info->id;
|
|
$h_row->user_id = $c_info->user_id;
|
|
$h_row->pdate = date('Y-m-d');
|
|
$h_row->ptime = '09:00';
|
|
$h_row->remark = '首次分配';
|
|
$h_row->save();
|
|
|
|
$this->addLog($c_info->id,'从E库分配数据给业务员:'.$c_info->user->getShowName(),1);
|
|
$index++;
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionCMoveD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$query = $this->getCQuery($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 3) {
|
|
$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);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionEMoveD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$query = $this->getEQuery($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 6) {
|
|
$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);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionFMoveD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
// echo 333;
|
|
// die;
|
|
|
|
if($request->isPost) {
|
|
|
|
$ids = $request->post('ids',array());
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$query = $this->getFQuery($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 7) {
|
|
$car_info->location = 4;
|
|
$car_info->save();
|
|
|
|
CarFT::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,'从F库分配到D库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionFMoveA()
|
|
{
|
|
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;
|
|
}
|
|
|
|
$query = $this->getFQuery($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 7) {
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarFT::deleteAll(['id'=>$car_info->id]);
|
|
$this->addLog($car_info->id,'从F库分配到A库',1);
|
|
// $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();
|
|
//
|
|
//
|
|
// }
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionF1MoveB()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
// echo 333;
|
|
// die;
|
|
|
|
if($request->isPost) {
|
|
|
|
$ids = $request->post('ids',array());
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$query = $this->getF1Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 8) {
|
|
$car_info->location = 2;
|
|
$car_info->save();
|
|
|
|
CarF1T::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$d_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$d_info) {
|
|
$d_info = new CarBT();
|
|
$d_info->id = $car_info->id;
|
|
$d_info->user_id = 0;
|
|
$d_info->save();
|
|
|
|
$this->addLog($car_info->id,'从F1库分配到B库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF1MoveA()
|
|
{
|
|
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;
|
|
}
|
|
|
|
$query = $this->getF1Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 8) {
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarF1T::deleteAll(['id'=>$car_info->id]);
|
|
$this->addLog($car_info->id,'从F1库分配到A库',1);
|
|
// $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();
|
|
//
|
|
//
|
|
// }
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF1B()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$query = $this->getF1Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 8) {
|
|
$car_info->location = 2;
|
|
$car_info->save();
|
|
|
|
CarF1T::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$d_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$d_info) {
|
|
$d_info = new CarBT();
|
|
$d_info->id = $car_info->id;
|
|
$d_info->user_id = 0;
|
|
$d_info->save();
|
|
|
|
$this->addLog($car_info->id,'从F1库分配到B库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionF2MoveD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
// echo 333;
|
|
// die;
|
|
|
|
if($request->isPost) {
|
|
|
|
$ids = $request->post('ids',array());
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$query = $this->getF2Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 9) {
|
|
$car_info->location = 2;
|
|
$car_info->save();
|
|
|
|
CarF2T::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$d_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$d_info) {
|
|
$d_info = new CarBT();
|
|
$d_info->id = $car_info->id;
|
|
$d_info->user_id = 0;
|
|
$d_info->save();
|
|
|
|
$this->addLog($car_info->id,'从F2库分配到B库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF2MoveA()
|
|
{
|
|
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;
|
|
}
|
|
|
|
$query = $this->getF2Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
dd($car_info->location);
|
|
if($car_info->location == 8) {
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
dd(32);
|
|
CarF2T::deleteAll(['id'=>$car_info->id]);
|
|
$this->addLog($car_info->id,'从F2库分配到A库',1);
|
|
// $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();
|
|
//
|
|
//
|
|
// }
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF2B()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$query = $this->getF2Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 9) {
|
|
$car_info->location = 2;
|
|
$car_info->save();
|
|
|
|
CarF2T::deleteAll(['id'=>$car_info->id]);
|
|
|
|
$d_info = CarBT::findOne(['id'=>$car_info->id]);
|
|
if(!$d_info) {
|
|
$d_info = new CarBT();
|
|
$d_info->id = $car_info->id;
|
|
$d_info->user_id = 0;
|
|
$d_info->save();
|
|
|
|
$this->addLog($car_info->id,'从F2库分配到B库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF4MoveD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
// echo 333;
|
|
// die;
|
|
|
|
if($request->isPost) {
|
|
|
|
$ids = $request->post('ids',array());
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$query = $this->getF4Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 11) {
|
|
$car_info->location = 4;
|
|
$car_info->save();
|
|
|
|
CarF4T::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,'从F4库分配到D库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF4MoveA()
|
|
{
|
|
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;
|
|
}
|
|
|
|
$query = $this->getF4Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 11) {
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarF4T::deleteAll(['id'=>$car_info->id]);
|
|
$this->addLog($car_info->id,'从F4库分配到A库',1);
|
|
// $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();
|
|
//
|
|
//
|
|
// }
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF4D()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$query = $this->getF4Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 11) {
|
|
$car_info->location = 4;
|
|
$car_info->save();
|
|
|
|
CarF4T::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,'从F4库分配到D库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF5MoveD()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
// echo 333;
|
|
// die;
|
|
|
|
if($request->isPost) {
|
|
|
|
$ids = $request->post('ids',array());
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$query = $this->getF4Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 12) {
|
|
$car_info->location = 4;
|
|
$car_info->save();
|
|
|
|
CarF5T::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,'从F5库分配到D库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF5MoveA()
|
|
{
|
|
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;
|
|
}
|
|
|
|
$query = $this->getF4Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 12) {
|
|
$car_info->location = 1;
|
|
$car_info->save();
|
|
|
|
CarF5T::deleteAll(['id'=>$car_info->id]);
|
|
$this->addLog($car_info->id,'从F5库分配到A库',1);
|
|
// $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();
|
|
//
|
|
//
|
|
// }
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
public function actionF5D()
|
|
{
|
|
Yii::$app->response->format = Response::FORMAT_JSON;
|
|
$request = Yii::$app->request;
|
|
$result = array();
|
|
$result['success'] = false;
|
|
$result['msg'] = '操作失败';
|
|
|
|
if($request->isPost) {
|
|
$status = $request->post('status');
|
|
if($status != 1) {
|
|
$result['msg'] = '请先选择分配状态!';
|
|
return $result;
|
|
}
|
|
$query = $this->getF4Query($request);
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($query->each(100) as $c_info) {
|
|
$car_info = CarT::findOne(['id'=>$c_info->id]);
|
|
if($car_info->location == 12) {
|
|
$car_info->location = 4;
|
|
$car_info->save();
|
|
|
|
CarF5T::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,'从F5库分配到D库',1);
|
|
}
|
|
}
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* E库分配
|
|
* @return array
|
|
*/
|
|
public function actionEAssign()
|
|
{
|
|
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',0);
|
|
|
|
if($user_id == 0) {
|
|
$result['msg'] = '请先选择分配给哪个业务员';
|
|
return $result;
|
|
}
|
|
if(count($ids) == 0) {
|
|
$result['msg'] = '请先钩选车辆';
|
|
return $result;
|
|
}
|
|
|
|
$tran = CarT::getDb()->beginTransaction();
|
|
try {
|
|
foreach($ids as $id) {
|
|
$c_info = CarET::findOne(['id'=>$id]);
|
|
|
|
if($c_info->user_id > 0) {
|
|
$result['msg'] = '该车辆已经被分配';
|
|
return $result;
|
|
}
|
|
$c_info->user_id = $user_id;
|
|
$c_info->save();
|
|
|
|
$car_info = $c_info->car;
|
|
$car_info->op_user2 = $c_info->user->getShowName();
|
|
$car_info->save();
|
|
|
|
//添加预约
|
|
AppointmentT::deleteAll('car_id='.$c_info->id);
|
|
$row = new AppointmentT();
|
|
$row->car_id = $c_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 = $c_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();
|
|
|
|
$this->addLog($c_info->id,'从E库分配跟踪数据到业务员:'.$c_info->user->getShowName(),1);
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function actionEReturn()
|
|
{
|
|
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) {
|
|
$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->save();
|
|
|
|
$c_info->user_id = 0;
|
|
$c_info->save();
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
//F库
|
|
private function getFQuery($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$print_begin = $request->post('print_begin');
|
|
$print_end = $request->post('print_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');
|
|
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$company = $request->post('company');
|
|
$user1 = $request->post('user1');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
}
|
|
$query = CarFT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_f_t`.`id`');
|
|
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($print_begin != '') {
|
|
$query = $query->andWhere('car_t.print_date>="'.$print_begin.'"');
|
|
}
|
|
if($print_end != '') {
|
|
$query = $query->andWhere('car_t.print_date<="'.$print_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_f_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_f_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_f_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query = $query->andWhere('car_t.old_user="'.$old_user.'"');
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like"'.$company.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('op_user1 like "'.$user1.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_f_t.id '.$sort_value);
|
|
//echo $query->createCommand()->rawSql;
|
|
return $query;
|
|
}
|
|
public function actionFIndex()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$engine_no = $request->get('engine_no');
|
|
$car_frame_no = $request->get('car_frame_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
|
|
$query = $this->getFQuery($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_f_t.id=-1');
|
|
}
|
|
//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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
return $this->render('f-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'engine_no' => $engine_no,
|
|
'car_frame_no' => $car_frame_no,
|
|
'print_begin' => $print_begin,
|
|
'print_end' => $print_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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'status' => $status,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'user_id' => $user_id,
|
|
'company' => $company,
|
|
'user1' => $user1
|
|
]);
|
|
}
|
|
private function getF1Query($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$print_begin = $request->post('print_begin');
|
|
$print_end = $request->post('print_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');
|
|
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$company = $request->post('company');
|
|
$user1 = $request->post('user1');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
}
|
|
$query = CarF1T::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_f1_t`.`id`');
|
|
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($print_begin != '') {
|
|
$query = $query->andWhere('car_t.print_date>="'.$print_begin.'"');
|
|
}
|
|
if($print_end != '') {
|
|
$query = $query->andWhere('car_t.print_date<="'.$print_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_f1_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_f1_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_f1_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query = $query->andWhere('car_t.old_user="'.$old_user.'"');
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like"'.$company.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('op_user1 like "'.$user1.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_f1_t.id '.$sort_value);
|
|
//echo $query->createCommand()->rawSql;
|
|
return $query;
|
|
}
|
|
public function actionF1Index()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$engine_no = $request->get('engine_no');
|
|
$car_frame_no = $request->get('car_frame_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
|
|
$query = $this->getF1Query($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_f1_t.id=-1');
|
|
}
|
|
//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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
return $this->render('f1-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'engine_no' => $engine_no,
|
|
'car_frame_no' => $car_frame_no,
|
|
'print_begin' => $print_begin,
|
|
'print_end' => $print_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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'status' => $status,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'user_id' => $user_id,
|
|
'company' => $company,
|
|
'user1' => $user1
|
|
]);
|
|
}
|
|
private function getF2Query($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$print_begin = $request->post('print_begin');
|
|
$print_end = $request->post('print_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');
|
|
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$company = $request->post('company');
|
|
$user1 = $request->post('user1');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
}
|
|
$query = CarF2T::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_f2_t`.`id`');
|
|
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($print_begin != '') {
|
|
$query = $query->andWhere('car_t.print_date>="'.$print_begin.'"');
|
|
}
|
|
if($print_end != '') {
|
|
$query = $query->andWhere('car_t.print_date<="'.$print_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_f2_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_f2_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_f2_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query = $query->andWhere('car_t.old_user="'.$old_user.'"');
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like"'.$company.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('op_user1 like "'.$user1.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_f2_t.id '.$sort_value);
|
|
//echo $query->createCommand()->rawSql;
|
|
return $query;
|
|
}
|
|
public function actionF2Index()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$engine_no = $request->get('engine_no');
|
|
$car_frame_no = $request->get('car_frame_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
|
|
$query = $this->getF2Query($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_f2_t.id=-1');
|
|
}
|
|
//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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
return $this->render('f2-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'engine_no' => $engine_no,
|
|
'car_frame_no' => $car_frame_no,
|
|
'print_begin' => $print_begin,
|
|
'print_end' => $print_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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'status' => $status,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'user_id' => $user_id,
|
|
'company' => $company,
|
|
'user1' => $user1
|
|
]);
|
|
}
|
|
private function getF4Query($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$print_begin = $request->post('print_begin');
|
|
$print_end = $request->post('print_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');
|
|
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$company = $request->post('company');
|
|
$user1 = $request->post('user1');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
}
|
|
$query = CarF4T::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_f4_t`.`id`');
|
|
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($print_begin != '') {
|
|
$query = $query->andWhere('car_t.print_date>="'.$print_begin.'"');
|
|
}
|
|
if($print_end != '') {
|
|
$query = $query->andWhere('car_t.print_date<="'.$print_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_f4_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_f4_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_f4_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query = $query->andWhere('car_t.old_user="'.$old_user.'"');
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like"'.$company.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('op_user1 like "'.$user1.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_f4_t.id '.$sort_value);
|
|
//echo $query->createCommand()->rawSql;
|
|
return $query;
|
|
}
|
|
public function actionF4Index()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$engine_no = $request->get('engine_no');
|
|
$car_frame_no = $request->get('car_frame_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
|
|
$query = $this->getF4Query($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_f4_t.id=-1');
|
|
}
|
|
//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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
return $this->render('f4-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'engine_no' => $engine_no,
|
|
'car_frame_no' => $car_frame_no,
|
|
'print_begin' => $print_begin,
|
|
'print_end' => $print_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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'status' => $status,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'user_id' => $user_id,
|
|
'company' => $company,
|
|
'user1' => $user1
|
|
]);
|
|
}
|
|
private function getF5Query($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$print_begin = $request->post('print_begin');
|
|
$print_end = $request->post('print_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');
|
|
|
|
$status = $request->post('status');
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$company = $request->post('company');
|
|
$user1 = $request->post('user1');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
}
|
|
$query = CarF5T::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_f5_t`.`id`');
|
|
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($print_begin != '') {
|
|
$query = $query->andWhere('car_t.print_date>="'.$print_begin.'"');
|
|
}
|
|
if($print_end != '') {
|
|
$query = $query->andWhere('car_t.print_date<="'.$print_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_f5_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_f5_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_f5_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query = $query->andWhere('car_t.old_user="'.$old_user.'"');
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like"'.$company.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('op_user1 like "'.$user1.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.', car_f5_t.id '.$sort_value);
|
|
//echo $query->createCommand()->rawSql;
|
|
return $query;
|
|
}
|
|
public function actionF5Index()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$engine_no = $request->get('engine_no');
|
|
$car_frame_no = $request->get('car_frame_no');
|
|
$print_begin = $request->get('print_begin');
|
|
$print_end = $request->get('print_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');
|
|
|
|
|
|
|
|
$status = $request->get('status');
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$user_id = $request->get('user_id');
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
$company = $request->get('company');
|
|
$user1 = $request->get('user1');
|
|
|
|
$query = $this->getF5Query($request);
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_f5_t.id=-1');
|
|
}
|
|
//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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTree();
|
|
$user_items = $this->my->getChildren();
|
|
$monthes= CarT::MONTH;
|
|
$days= CarT::DAYS;
|
|
return $this->render('f5-index',[
|
|
'items' => $items,
|
|
'monthes' => $monthes,
|
|
'days' => $days,
|
|
'page_info' => $page_info,
|
|
'page' => $page,
|
|
'car_man' => $car_man,
|
|
'phone' => $phone,
|
|
'car_no' => $car_no,
|
|
'engine_no' => $engine_no,
|
|
'car_frame_no' => $car_frame_no,
|
|
'print_begin' => $print_begin,
|
|
'print_end' => $print_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,
|
|
'invalid_items' => $invalid_items,
|
|
'user_items' => $user_items,
|
|
'status' => $status,
|
|
'username' => $username,
|
|
'sort_key' => $sort_key,
|
|
'sort_value' => $sort_value,
|
|
'user_id' => $user_id,
|
|
'company' => $company,
|
|
'user1' => $user1
|
|
]);
|
|
}
|
|
|
|
private function getDQuery1($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$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');
|
|
$status = $request->post('status',1);
|
|
$username = $request->post('username');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
$old_user = $request->post('old_user');
|
|
$user1 = $request->post('user1');
|
|
$user2 = $request->post('user2');
|
|
$company = $request->post('company');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$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');
|
|
$status = $request->get('status',1);
|
|
$username = $request->get('username');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
$old_user = $request->get('old_user');
|
|
$user1 = $request->get('user1');
|
|
$user2 = $request->get('user2');
|
|
$company = $request->get('company');
|
|
}
|
|
$params = array();
|
|
$params['car_man'] = $car_man;
|
|
$params['phone'] = $phone;
|
|
$params['car_no'] = $car_no;
|
|
$params['insurer1_begin'] = $insurer1_begin;
|
|
$params['insurer1_end'] = $insurer1_end;
|
|
$params['insurer1_month'] = $insurer1_month;
|
|
$params['insurer1_day'] = $insurer1_day;
|
|
$params['insurer1_month1'] = $insurer1_month1;
|
|
$params['insurer1_day1'] = $insurer1_day1;
|
|
$params['status'] = $status;
|
|
$params['username'] = $username;
|
|
$params['sort_key'] = $sort_key;
|
|
$params['sort_value'] = $sort_value;
|
|
$params['old_user'] = $old_user;
|
|
$params['user1'] = $user1;
|
|
$params['user2'] = $user2;
|
|
$params['company'] = $company;
|
|
|
|
$query = CarDT::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_d_t`.`id`')
|
|
->andWhere('car_d_t.back =1');
|
|
if($car_man != '') {
|
|
$query = $query->andWhere('car_t.car_man="'.$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($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_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.'"');
|
|
}
|
|
if($status == 1) {
|
|
$query = $query->andWhere('car_d_t.user_id=0');
|
|
}
|
|
if($status == 2) {
|
|
$query = $query->andWhere('car_d_t.user_id>0');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_d_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
if($old_user != '') {
|
|
$query = $query->andWhere('car_t.old_user like "'.$old_user.'%"');
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('car_t.op_user1 like "'.$user1.'%"');
|
|
}
|
|
if($user2 != '') {
|
|
$query = $query->andWhere('car_t.op_user3 like "'.$user2.'%"');
|
|
}
|
|
if($company != '') {
|
|
$query = $query->andWhere('company like "'.$company.'%"');
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.',car_d_t.id '.$sort_value);
|
|
return ['query'=>$query,'params'=>$params];
|
|
}
|
|
|
|
public function actionDataDReturn()
|
|
{
|
|
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) {
|
|
$d_info = CarDT::findOne(['id'=>$id]);
|
|
if($d_info->user_id > 0){
|
|
$car_info = $d_info->car;
|
|
$car_info->user_id = 0;
|
|
$car_info->save();
|
|
|
|
$this->addLog($d_info->id,'从业务员:'.$d_info->user->getShowName().'收回数据',1);
|
|
$d_info->user_id=0;
|
|
$d_info->save();
|
|
|
|
|
|
|
|
|
|
//删除预约
|
|
$row = AppointmentT::find()
|
|
->where('user_id='.$d_info->user_id.' and car_id='.$d_info->id)
|
|
->one();
|
|
if($row) {
|
|
$row->delete();
|
|
}
|
|
|
|
//删除保单
|
|
$order_row = OrderT::find()
|
|
->where('user_id='.$d_info->user_id.' and car_id='.$d_info->id.' and status_id=1')
|
|
->one();
|
|
if($order_row) {
|
|
OrderUserT::deleteAll('order_id='.$order_row->id);
|
|
$order_row->delete();
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
$result['success'] = true;
|
|
$result['msg'] = '操作成功';
|
|
|
|
$tran->commit();
|
|
} catch (\Exception $e) {
|
|
$tran->rollBack();
|
|
echo $e->getMessage();
|
|
}
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
private function getInvalidQuery1($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
$invalid_id = $request->post('invalid_id');
|
|
$username = $request->post('username');
|
|
$user1 = $request->post('user1');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$register_begin = $request->get('register_begin');
|
|
$register_end = $request->get('register_end');
|
|
$insurer1_begin = $request->get('insurer1_begin');
|
|
$insurer1_end = $request->get('insurer1_end');
|
|
$invalid_id = $request->get('invalid_id');
|
|
$username = $request->get('username');
|
|
$user1 = $request->get('user1');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
}
|
|
$params = array();
|
|
$params['car_man'] = $car_man;
|
|
$params['phone'] = $phone;
|
|
$params['car_no'] = $car_no;
|
|
$params['register_begin'] = $register_begin;
|
|
$params['register_end'] = $register_end;
|
|
$params['insurer1_begin'] = $insurer1_begin;
|
|
$params['insurer1_end'] = $insurer1_end;
|
|
$params['invalid_id'] = $invalid_id;
|
|
$params['username'] = $username;
|
|
$params['user1'] = $user1;
|
|
$params['sort_key'] = $sort_key;
|
|
$params['sort_value'] = $sort_value;
|
|
|
|
$query = CarF3T::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_f3_t`.`id`');
|
|
|
|
if($car_man != '') {
|
|
$query = $query->andWhere('car_t.car_man="'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query = $query->andWhere('car_t.phone="'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
$query = $query->andWhere('car_t.car_no="'.$car_no.'"');
|
|
}
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($invalid_id > 0) {
|
|
$query = $query->andWhere('car_invalid_t.invalid_id='.$invalid_id);
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('car_t.op_user1 like "'.$user1.'%"');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_f3_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.',car_f3_t.id '.$sort_value);
|
|
// echo $query->createCommand()->rawSql;
|
|
return ['query'=>$query,'params'=>$params];
|
|
}
|
|
|
|
public function actionInvalidIndex1()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
|
|
$data = $this->getInvalidQuery1($request);
|
|
$query = $data['query'];
|
|
$params = $data['params'];
|
|
$params['page'] = $page;
|
|
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_f3_t.id=-1');
|
|
}
|
|
|
|
// 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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTreeXinbaoNew(2);
|
|
|
|
$params['items'] = $items;
|
|
$params['page_info'] = $page_info;
|
|
$params['invalid_items'] = $invalid_items;
|
|
|
|
return $this->render('f3-index',$params);
|
|
}
|
|
private function getInvalidQuery2($request)
|
|
{
|
|
if($request->isPost) {
|
|
$car_man = $request->post('car_man');
|
|
$phone = $request->post('phone');
|
|
$car_no = $request->post('car_no');
|
|
$register_begin = $request->post('register_begin');
|
|
$register_end = $request->post('register_end');
|
|
$insurer1_begin = $request->post('insurer1_begin');
|
|
$insurer1_end = $request->post('insurer1_end');
|
|
$invalid_id = $request->post('invalid_id');
|
|
$username = $request->post('username');
|
|
$user1 = $request->post('user1');
|
|
$sort_key = $request->post('sort_key');
|
|
$sort_value = $request->post('sort_value');
|
|
} else {
|
|
$car_man = $request->get('car_man');
|
|
$phone = $request->get('phone');
|
|
$car_no = $request->get('car_no');
|
|
$register_begin = $request->get('register_begin');
|
|
$register_end = $request->get('register_end');
|
|
$insurer1_begin = $request->get('insurer1_begin');
|
|
$insurer1_end = $request->get('insurer1_end');
|
|
$invalid_id = $request->get('invalid_id');
|
|
$username = $request->get('username');
|
|
$user1 = $request->get('user1');
|
|
$sort_key = $request->get('sort_key');
|
|
$sort_value = $request->get('sort_value');
|
|
}
|
|
$params = array();
|
|
$params['car_man'] = $car_man;
|
|
$params['phone'] = $phone;
|
|
$params['car_no'] = $car_no;
|
|
$params['register_begin'] = $register_begin;
|
|
$params['register_end'] = $register_end;
|
|
$params['insurer1_begin'] = $insurer1_begin;
|
|
$params['insurer1_end'] = $insurer1_end;
|
|
$params['invalid_id'] = $invalid_id;
|
|
$params['username'] = $username;
|
|
$params['user1'] = $user1;
|
|
$params['sort_key'] = $sort_key;
|
|
$params['sort_value'] = $sort_value;
|
|
|
|
$query = CarF6T::find()
|
|
->leftJoin(CarT::tableName(),'`car_t`.`id`=`car_f6_t`.`id`');
|
|
|
|
if($car_man != '') {
|
|
$query = $query->andWhere('car_t.car_man="'.$car_man.'"');
|
|
}
|
|
if($phone != '') {
|
|
$query = $query->andWhere('car_t.phone="'.$phone.'"');
|
|
}
|
|
if($car_no != '') {
|
|
$query = $query->andWhere('car_t.car_no="'.$car_no.'"');
|
|
}
|
|
if($register_begin != '') {
|
|
$query = $query->andWhere('car_t.register_date>="'.$register_begin.'"');
|
|
}
|
|
if($register_end != '') {
|
|
$query = $query->andWhere('car_t.register_date<="'.$register_end.'"');
|
|
}
|
|
if($insurer1_begin != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date>="'.$insurer1_begin.'"');
|
|
}
|
|
if($insurer1_end != '') {
|
|
$query = $query->andWhere('car_t.insurer1_date<="'.$insurer1_end.'"');
|
|
}
|
|
if($invalid_id > 0) {
|
|
$query = $query->andWhere('car_invalid_t.invalid_id='.$invalid_id);
|
|
}
|
|
if($user1 != '') {
|
|
$query = $query->andWhere('car_t.op_user1 like "'.$user1.'%"');
|
|
}
|
|
if($username != '') {
|
|
$user_info = UserT::findOne(['username'=>$username]);
|
|
if($user_info) {
|
|
$query = $query->andWhere('car_f6_t.user_id='.$user_info->id);
|
|
}
|
|
}
|
|
$query = $query->orderBy($sort_key.' '.$sort_value.',car_f6_t.id '.$sort_value);
|
|
// echo $query->createCommand()->rawSql;
|
|
return ['query'=>$query,'params'=>$params];
|
|
}
|
|
|
|
public function actionInvalidIndex2()
|
|
{
|
|
$request = Yii::$app->request;
|
|
$page = $request->get('page',1);
|
|
$op = $request->get('op',1);
|
|
|
|
$data = $this->getInvalidQuery2($request);
|
|
$query = $data['query'];
|
|
$params = $data['params'];
|
|
$params['page'] = $page;
|
|
|
|
if($op==0) {
|
|
$query = $query->andWhere('car_f6_t.id=-1');
|
|
}
|
|
|
|
// 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();
|
|
|
|
$page_info = MyLib::getPageInfo($pagination);
|
|
|
|
$invalid_items = InvalidT::getTreeXubao(2);
|
|
|
|
$params['items'] = $items;
|
|
$params['page_info'] = $page_info;
|
|
$params['invalid_items'] = $invalid_items;
|
|
|
|
return $this->render('f6-index',$params);
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|