123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218 |
- <?php
- namespace app\admin\controller;
- use app\admin\model\ChangeLog;
- use app\BaseController;
- use think\App;
- use think\facade\Db;
- class Unit extends Base
- {
- public $post = "";
- public function __construct(App $app)
- {
- parent::__construct($app);
- $this->post = $this->request->post();
- }
- public function create()
- {
- $param = $this->request->only(['unit', 'status' => 1], 'post', 'trim');
- if ($param['unit'] == "") return error_show(1002, "参数unit不能为空");
- $tmp = Db::name("unit")
- ->field('id')
- ->where(['is_del' => 0, "unit" => $param['unit']])
- ->findOrEmpty();
- if (!empty($tmp)) return json_show(1004, '该单位已存在');
- $createrid = $this->uid;
- $creater = $this->uname;
- $data = [
- "unit" => $param['unit'],
- "creater" => $creater,
- "createrid" => $createrid,
- "status" => $param['status'],
- "is_del" => 0,
- "addtime" => date("Y-m-d H:i:s"),
- "updatetime" => date("Y-m-d H:i:s")
- ];
- $info = Db::name("unit")->insert($data);
- return $info ? json_show(0, "新建成功") : json_show(1002, "新建失败");
- }
- public function list()
- {
- $page = isset($this->post['page']) && $this->post['page'] !== "" ? intval($this->post['page']) : "1";
- $size = isset($this->post['size']) && $this->post['size'] !== "" ? intval($this->post['size']) : "10";
- $where = [["u.is_del", "=", 0]];
- $unit = isset($this->post['unit']) && $this->post['unit'] !== "" ? trim($this->post['unit']) : "";
- if ($unit !== "") {
- $where[] = ['u.unit', "like", "%$unit%"];
- }
- $status = isset($this->post['status']) && $this->post['status'] !== "" ? intval($this->post['status']) : "";
- if ($status !== "") {
- $where[] = ['u.status', "=", $status];
- }
- $creater = isset($this->post['creater']) && $this->post['creater'] !== "" ? trim($this->post['creater']) : "";
- if ($creater != "") {
- $where[] = ['u.creater', "like", "%$creater%"];
- }
- $start = isset($this->post['start']) && $this->post['start'] !== "" ? $this->post['start'] : "";
- if ($start !== "") {
-
- $where[] = ['u.addtime', ">=", $start];
- }
- $end = isset($this->post['end']) && $this->post['end'] !== "" ? $this->post['end'] : "";
- if ($end !== "") {
-
- $where[] = ['u.addtime', "<=", $end];
- }
- $company_name = isset($this->post['company_name']) && $this->post['company_name'] !== "" ? trim($this->post['company_name']) : "";
- if ($company_name !== "") $where[] = ["u.createrid", 'in', get_company_item_user_by_name($company_name)];
- $count = Db::name('unit')
- ->alias('u')
- ->leftJoin("depart_user user", "user.uid=u.createrid AND user.is_del=0")
- ->where($where)
- ->count();
- $total = ceil($count / $size);
- $page = $page >= $total ? $total : $page;
- $list = Db::name('unit')
- ->alias('u')
- ->where($where)
- ->append(['company_name'])
- ->page($page, $size)
- ->order("addtime desc")
- ->select()
- ->toArray();
- $all_createrid = array_column($list, 'createrid');
- $item = get_company_name_by_uid($all_createrid);
- foreach ($list as &$val) {
- $val['company_name'] = $item[$val['createrid']] ?? '';
- }
- return app_show(0, "获取成功", ['list' => $list, 'count' => $count]);
- }
- public function edit()
- {
- $id = isset($this->post['id']) && $this->post['id'] !== "" ? intval($this->post['id']) : "";
- if ($id == "") {
- return error_show(1002, "参数id不能为空");
- }
- $info = Db::name('unit')->where(['id' => $id, 'is_del' => 0])->find();
- if ($info == "") {
- return error_show(1003, "未找到数据");
- }
- if ($info['status'] == 1) {
- return error_show(1002, "状态是启用状态,无法编辑");
- }
- $unit = isset($this->post['unit']) && $this->post['unit'] !== "" ? trim($this->post['unit']) : "";
- if ($unit == "") {
- return error_show(1002, "参数unit不能为空");
- }
- $status = isset($this->post['status']) && $this->post['status'] !== "" ? intval($this->post['status']) : "0";
- $tmp = Db::name("unit")
- ->field('id')
- ->where(['is_del' => 0, "unit" => $unit])
- ->where('id','<>',$id)
- ->findOrEmpty();
- if (!empty($tmp)) return json_show(1004, '该单位已存在');
- $data = [
- "id" => $id,
- "unit" => $unit,
-
- "is_del" => 0,
- "updatetime" => date("Y-m-d H:i:s")
- ];
- $datainfo = Db::name('unit')->where(['is_del'=>0,'id'=>$id])->save($data);
- $item = array_diff($data, $info);
- $json = json_encode($item, JSON_UNESCAPED_UNICODE);
- $jsp = json_encode($info, JSON_UNESCAPED_UNICODE);
- if ($datainfo) {
- ChangeLog::logAdd(4, $info['id'], $jsp, $json, ['id' => $this->uid, 'nickname' => $this->uname]);
- return error_show(0, "更新成功");
- } else {
- return error_show(1002, "更新失败");
- }
- }
- public function del()
- {
- $id = $this->post['id'] && $this->post['id'] !== "" ? intval($this->post['id']) : "";
- if ($id === "") {
- return error_show(1004, "参数id不能为空");
- }
- $str = Db::name('unit')->where(['id' => $id, 'is_del' => 0])->find();
- if (empty($str)) {
- return error_show(1002, "未找到数据");
- }
- $end = Db::name('unit')->update(['id' => $id, 'is_del' => 1]);
- if ($end) {
- return error_show(0, "删除成功");
- } else {
- return error_show(1002, "删除失败");
- }
- }
- public function status()
- {
- $id = isset($this->post['id']) && $this->post['id'] !== "" ? intval($this->post['id']) : "";
- if ($id == "") {
- return error_show(1002, "参数id不能为空");
- }
- $info = Db::name("unit")->where([["id", "=", $id], ["is_del", "=", 0]])->find();
- if (!$info) {
- return error_show(1002, "未找到对应数据");
- }
- $status = isset($this->post['status']) && $this->post['status'] !== "" ? intval($this->post['status']) : "";
- if ($status === "") {
- return error_show(1002, "参数status不能为空");
- }
- if (!in_array($status, [0, 1])) {
- return error_show(1002, "参数status无效");
- }
- $info['status'] = $status;
- $info['updatetime'] = date("Y-m-d H:i:s");
- $msg = $status == 1 ? "启用" : "禁用";
- $update = Db::name("unit")->save($info);
- return $update ? error_show(0, "{$msg}成功") : error_show(1004, "{$msg}失败");
- }
- }
|