...
|
...
|
@@ -4,6 +4,9 @@ namespace app\admin\controller; |
|
|
|
|
|
use app\common\controller\Backend;
|
|
|
use app\common\controller\Resource;
|
|
|
use think\Db;
|
|
|
use think\exception\PDOException;
|
|
|
use think\exception\ValidateException;
|
|
|
|
|
|
/**
|
|
|
* 学生管理
|
...
|
...
|
@@ -70,20 +73,6 @@ class Study extends Backend |
|
|
return $this->view->fetch();
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 生成现场二维码
|
|
|
*/
|
|
|
public function barcode($ids)
|
|
|
{
|
|
|
$barcode = $this->model->where('id', $ids)->value('barcode');
|
|
|
if (!empty($barcode)) {
|
|
|
$this->error('已生成条形码,无需重复生成');
|
|
|
}
|
|
|
$brpath = Resource::StudyBar($ids);
|
|
|
halt($brpath);
|
|
|
$this->model->save(['barcode' => $brpath], ['id' => $ids]);
|
|
|
$this->success('操作成功');
|
|
|
}
|
|
|
|
|
|
|
|
|
//导出数据
|
...
|
...
|
@@ -159,4 +148,49 @@ class Study extends Backend |
|
|
exit;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 添加
|
|
|
*
|
|
|
* @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);
|
|
|
|
|
|
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);
|
|
|
}
|
|
|
$result = $this->model->allowField(true)->save($params);
|
|
|
$id = $this->model->id;
|
|
|
$brpath = Resource::StudyBar($id);
|
|
|
$this->model->save(['barcode'=>$brpath],['id'=>$id]);
|
|
|
Db::commit();
|
|
|
} catch (ValidateException|PDOException|Exception $e) {
|
|
|
Db::rollback();
|
|
|
$this->error($e->getMessage());
|
|
|
}
|
|
|
if ($result === false) {
|
|
|
$this->error(__('No rows were inserted'));
|
|
|
}
|
|
|
$this->success();
|
|
|
}
|
|
|
|
|
|
} |
...
|
...
|
|