...
|
...
|
@@ -29,6 +29,7 @@ class Order extends Backend |
|
|
parent::_initialize();
|
|
|
$this->model = new \app\admin\model\Order;
|
|
|
$this->view->assign("isPayList", $this->model->getIsPayList());
|
|
|
$this->view->assign("typeList", $this->model->gettypeList());
|
|
|
}
|
|
|
|
|
|
|
...
|
...
|
@@ -235,6 +236,8 @@ class Order extends Backend |
|
|
$row['pay_type']="微信";
|
|
|
}elseif($row['pay_type']=="offlinepay"){
|
|
|
$row['pay_type']="线下";
|
|
|
}elseif($row['pay_type']=="background"){
|
|
|
$row['pay_type']="后台下单";
|
|
|
}
|
|
|
$route=Db::name("route")->find($row['route_id']);
|
|
|
$row['route_name']=$route['name'];
|
...
|
...
|
@@ -271,4 +274,101 @@ class Order extends Backend |
|
|
return $res;
|
|
|
}
|
|
|
}
|
|
|
} |
|
|
|
|
|
/**
|
|
|
* 检查是否有新订单
|
|
|
* @return void
|
|
|
*/
|
|
|
public function chackordershow(){
|
|
|
$res=Db::name("order")->where("is_show",0)->select();
|
|
|
$isreturn=0;
|
|
|
if(!empty($res)){
|
|
|
$isreturn=1;
|
|
|
$updateres=Db::name("order")->where("is_show",0)->update(["is_show"=>1]);
|
|
|
return $isreturn;
|
|
|
}else{
|
|
|
return $isreturn;
|
|
|
}
|
|
|
}
|
|
|
/**
|
|
|
* 添加
|
|
|
*
|
|
|
* @return string
|
|
|
* @throws \think\Exception
|
|
|
*/
|
|
|
public function add()
|
|
|
{
|
|
|
if (false === $this->request->isPost()) {
|
|
|
return $this->view->fetch();
|
|
|
}
|
|
|
$params = $this->request->post('row/a');
|
|
|
if (empty($params)) {
|
|
|
$this->error(__('Parameter %s can not be empty', ''));
|
|
|
}
|
|
|
$params = $this->preExcludeFields($params);
|
|
|
$params['pay_type']="background";
|
|
|
$params['is_pay']=1;
|
|
|
$driver=Db::name("driver")->where("id",$params['driver_id'])->find();
|
|
|
$params['driver_name']=$driver['name'];
|
|
|
$params['order_no']=$this->getOrderSn();
|
|
|
if ($this->dataLimit && $this->dataLimitFieldAutoFill) {
|
|
|
$params[$this->dataLimitField] = $this->auth->id;
|
|
|
}
|
|
|
$result = false;
|
|
|
Db::startTrans();
|
|
|
try {
|
|
|
//是否采用模型验证
|
|
|
if ($this->modelValidate) {
|
|
|
$name = str_replace("\\model\\", "\\validate\\", get_class($this->model));
|
|
|
$validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.add' : $name) : $this->modelValidate;
|
|
|
$this->model->validateFailException()->validate($validate);
|
|
|
}
|
|
|
|
|
|
$passenger=Db::name("passenger")->insertGetId(['name'=>$params['user_name'],'IDcard'=>$params['IDcard'],'phone'=>$params['phone']]);
|
|
|
$params['passengers']=$passenger;
|
|
|
//判断总表
|
|
|
$time = strtotime(date("Y-m-d", time()));
|
|
|
$order_review = Db::name("order_review")
|
|
|
->where("car_id", $params['car_id'])
|
|
|
->where("route_id", $params['route_id'])
|
|
|
->where("driver_id", $params['driver_id'])
|
|
|
->where("createtime", ">", $time)
|
|
|
->find();
|
|
|
|
|
|
if (!$order_review) {
|
|
|
$order_review_id = Db::name("order_review")
|
|
|
->insertGetId([
|
|
|
"car_id" => $params['car_id'],
|
|
|
"route_id" => $params['route_id'],
|
|
|
"driver_id" => $params['driver_id'],
|
|
|
"type" => 1,
|
|
|
"order_status" => 1,
|
|
|
"createtime" => time()
|
|
|
]);
|
|
|
} else {
|
|
|
$order_review_id = $order_review['id'];
|
|
|
}
|
|
|
$params['order_review_id']=$order_review_id;
|
|
|
$result = $this->model->allowField(true)->save($params);
|
|
|
Db::commit();
|
|
|
} catch (ValidateException|PDOException|Exception $e) {
|
|
|
Db::rollback();
|
|
|
$this->error($e->getMessage());
|
|
|
}
|
|
|
if ($result === false) {
|
|
|
$this->error(__('No rows were inserted'));
|
|
|
}
|
|
|
$this->success();
|
|
|
}
|
|
|
function getOrderSn()
|
|
|
{
|
|
|
$orderid = date("YmdHis") . mt_rand(1000, 999999);
|
|
|
$odcks = \think\Db::name('order')
|
|
|
->where(['order_no' => $orderid])
|
|
|
->find();
|
|
|
while (!empty($odcks)) {
|
|
|
$orderid = date("YmdHis") . mt_rand(1000, 999999);
|
|
|
}
|
|
|
return $orderid;
|
|
|
}
|
|
|
} |
|
|
\ No newline at end of file |
...
|
...
|
|