| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- <?php
- // +----------------------------------------------------------------------
- // | EasyAdmin
- // +----------------------------------------------------------------------
- // | PHP交流群: 763822524
- // +----------------------------------------------------------------------
- // | 开源协议 https://mit-license.org
- // +----------------------------------------------------------------------
- // | github开源项目:https://github.com/zhongshaofa/EasyAdmin
- // +----------------------------------------------------------------------
- namespace app\admin\traits;
- use EasyAdmin\annotation\NodeAnotation;
- use EasyAdmin\tool\CommonTool;
- use jianyan\excel\Excel;
- use think\facade\Db;
- /**
- * 后台CURD复用
- * Trait Curd
- * @package app\admin\traits
- */
- trait Curd
- {
- /**
- * @NodeAnotation(title="列表")
- */
- public function index()
- {
- if ($this->request->isAjax()) {
- if (input('selectFields')) {
- return $this->selectList();
- }
- list($page, $limit, $where) = $this->buildTableParames();
- $count = $this->model
- ->where($where)
- ->count();
- $list = $this->model
- ->where($where)
- ->page($page, $limit)
- ->order($this->sort)
- ->select();
- $data = [
- 'code' => 0,
- 'msg' => '',
- 'count' => $count,
- 'data' => $list,
- ];
- return json($data);
- }
- return $this->fetch();
- }
- /**
- * @NodeAnotation(title="添加")
- */
- public function add()
- {
- if ($this->request->isPost()) {
- $post = $this->request->post();
- $rule = [];
- $this->validate($post, $rule);
- try {
- $save = $this->model->save($post);
- } catch (\Exception $e) {
- $this->error('保存失败:'.$e->getMessage());
- }
- $save ? $this->success('保存成功') : $this->error('保存失败');
- }
- return $this->fetch();
- }
- /**
- * @NodeAnotation(title="编辑")
- */
- public function edit($id)
- {
- $row = $this->model->find($id);
- empty($row) && $this->error('数据不存在');
- if ($this->request->isPost()) {
- $post = $this->request->post();
- $rule = [];
- $this->validate($post, $rule);
- try {
- $save = $row->save($post);
- } catch (\Exception $e) {
- $this->error('保存失败');
- }
- $save ? $this->success('保存成功') : $this->error('保存失败');
- }
- $this->assign('row', $row);
- return $this->fetch();
- }
- /**
- * @NodeAnotation(title="删除")
- */
- public function delete($id)
- {
- $this->checkPostRequest();
- $row = $this->model->whereIn('id', $id)->select();
- $row->isEmpty() && $this->error('数据不存在');
- try {
- $save = $row->delete();
- } catch (\Exception $e) {
- $this->error('删除失败');
- }
- $save ? $this->success('删除成功') : $this->error('删除失败');
- }
- /**
- * @NodeAnotation(title="导出")
- */
- public function export()
- {
- list($page, $limit, $where) = $this->buildTableParames();
- $header = getExportHeader($modelName);
- $list = $this->model
- ->where($where)
- ->limit(100000)
- ->order('id', 'desc')
- ->select()
- ->toArray();
- $fileName = time();
- return Excel::exportData($list, $header, $fileName, 'xlsx');
- }
- /**
- * @NodeAnotation(title="属性修改")
- */
- public function modify()
- {
- $this->checkPostRequest();
- $post = $this->request->post();
- $rule = [
- 'id|ID' => 'require',
- 'field|字段' => 'require',
- 'value|值' => 'require',
- ];
- $this->validate($post, $rule);
- $row = $this->model->find($post['id']);
- if (!$row) {
- $this->error('数据不存在');
- }
- if (!in_array($post['field'], $this->allowModifyFields)) {
- $this->error('该字段不允许修改:' . $post['field']);
- }
- try {
- $row->save([
- $post['field'] => $post['value'],
- ]);
- } catch (\Exception $e) {
- $this->error($e->getMessage());
- }
- $this->success('保存成功');
- }
- }
|