187 lines
5.9 KiB
PHP
187 lines
5.9 KiB
PHP
<?php
|
||
|
||
namespace app\admin\controller\orders;
|
||
|
||
use app\admin\model\Admin;
|
||
use app\admin\model\Order;
|
||
use app\admin\model\Worker;
|
||
use app\common\controller\Backend;
|
||
use think\Db;
|
||
use think\Exception;
|
||
use think\exception\DbException;
|
||
use think\exception\PDOException;
|
||
use think\exception\ValidateException;
|
||
use think\Hook;
|
||
|
||
/**
|
||
* 订单列管理
|
||
*
|
||
* @icon fa fa-circle-o
|
||
*/
|
||
class Configorder extends Backend
|
||
{
|
||
|
||
/**
|
||
* Configorder模型对象
|
||
* @var Order
|
||
*/
|
||
protected $model = null;
|
||
|
||
public function _initialize()
|
||
{
|
||
parent::_initialize();
|
||
$this->model = new Order();
|
||
$this->view->assign("statusList", $this->model->getStatusList());
|
||
$this->view->assign("offlineTotalTypeList", $this->model->getOfflineTotalTypeList());
|
||
|
||
}
|
||
|
||
|
||
|
||
/**
|
||
* 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法
|
||
* 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑
|
||
* 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
|
||
*/
|
||
|
||
|
||
/**
|
||
* 查看
|
||
*/
|
||
public function index()
|
||
{
|
||
//当前是否为关联查询
|
||
$this->relationSearch = false;
|
||
//设置过滤方法
|
||
$this->request->filter(['strip_tags', 'trim']);
|
||
if ($this->request->isAjax()) {
|
||
//如果发送的来源是Selectpage,则转发到Selectpage
|
||
if ($this->request->request('keyField')) {
|
||
return $this->selectpage();
|
||
}
|
||
list($where, $sort, $order, $offset, $limit) = $this->buildparams();
|
||
$list = $this->model
|
||
->tab(Order::TAB_SETTING)
|
||
->configauth($this->auth,'dispatch_admin_id')
|
||
//->areaauth($this->auth)
|
||
->with(['dispatchadmin'])
|
||
->where($where);
|
||
|
||
|
||
$list = $list->order($sort, $order)
|
||
->paginate($limit);
|
||
|
||
foreach ($list as $row)
|
||
{
|
||
|
||
}
|
||
|
||
$result = array("total" => $list->total(), "rows" => $list->items());
|
||
|
||
return json($result);
|
||
}
|
||
return $this->view->fetch();
|
||
}
|
||
|
||
|
||
|
||
/**
|
||
* 编辑
|
||
*
|
||
* @param $ids
|
||
* @return string
|
||
* @throws DbException
|
||
* @throws \think\Exception
|
||
*/
|
||
public function edit($ids = null)
|
||
{
|
||
$row = $this->model->get($ids,['dispatch']);
|
||
if (!$row) {
|
||
$this->error(__('No Results were found'));
|
||
}
|
||
$adminIds = $this->getDataLimitAdminIds();
|
||
if (is_array($adminIds) && !in_array($row[$this->dataLimitField], $adminIds)) {
|
||
$this->error(__('You have no permission'));
|
||
}
|
||
if (false === $this->request->isPost()) {
|
||
$this->view->assign('row', $row);
|
||
$worker = Worker::where('id',$row->worker_id)->find();
|
||
$this->view->assign('worker', $worker);
|
||
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);
|
||
|
||
if(!in_array($row->status,[Order::STATUS_CHECKING,Order::STATUS_CHECKONCE])){
|
||
$this->error('订单不允许操作');
|
||
}
|
||
$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 . '.edit' : $name) : $this->modelValidate;
|
||
$row->validateFailException()->validate($validate);
|
||
}
|
||
|
||
$data = [
|
||
'status' => Order::STATUS_AUDITING,
|
||
'online_amount_last' => $params['online_amount_last'],
|
||
'offline_amount' => $params['offline_amount'],
|
||
// 'refund_amount' => $params['refund_amount'],
|
||
'cost' => $params['cost'],
|
||
'offline_amount_type'=> $params['offline_amount_type'],
|
||
'amount_images' => $params['amount_images'],
|
||
'material_cost' => $params['material_cost'],
|
||
'cost_rate' => $params['cost_rate'],
|
||
'cost_remark' => $params['cost_remark'] ?? '',
|
||
'material_images' => $params['material_images'] ?? '',
|
||
'off_images' => $params['off_images']?? '',
|
||
];
|
||
|
||
$last_amount = bcadd($params['online_amount_last'],$params['offline_amount'],2);
|
||
|
||
$cost = bcadd($params['cost'],$params['material_cost'],2);
|
||
|
||
$data['total'] = bcadd($row->online_amount,$last_amount,2);
|
||
$data['real_amount'] = $data['total'];
|
||
$data['performance'] = bcsub($data['real_amount'],$cost,2);
|
||
$result = $row->allowField(true)->save($data);
|
||
|
||
//日志
|
||
$params['order'] = $row;
|
||
$params['role'] = 1;
|
||
$params['auth'] = $this->auth;
|
||
$params['remark'] = '完成订单配置';
|
||
|
||
Hook::listen('order_change', $params);
|
||
|
||
Db::commit();
|
||
} catch (ValidateException|PDOException|Exception $e) {
|
||
Db::rollback();
|
||
$this->error($e->getMessage());
|
||
}
|
||
if (false === $result) {
|
||
$this->error(__('No rows were updated'));
|
||
}
|
||
$this->success();
|
||
}
|
||
|
||
|
||
public function getadminuser(){
|
||
|
||
$groupId = 6;
|
||
|
||
//$adminIds = Db::name('auth_group_access')->where('group_id',$groupId)->column('uid');
|
||
//whereIn('id',$adminIds)
|
||
$adminUsers = Admin::field(['id','nickname as name'])->select();
|
||
|
||
return json($adminUsers);
|
||
}
|
||
|
||
}
|