isAjax()) { $param = get_params(); $rows = empty($param['limit']) ? get_md_contentconfig('app.page_size') : $param['limit']; $list = WorkOrderList::withoutField('') ->where('delete_time', null) ->order(['status' => 'asc', 'id' => 'desc']) ->paginate($rows, false, ['query' => $param]) ->each(function ($item, $key) { $wo = WorkOrderList::where(['id' => $item->id])->find(); $projectName = Db::name('Project')->where('id', $wo['project_id'])->value('name_short'); $item->project_id = $projectName ?: '-'; $item->problemtype = $wo['problemtype']; $item->uid = $wo['uid']; $item->username = $wo['username']; if (!empty($wo['contact'])) { $item->contact = $wo['contact']; } else { $item->contact = Db::name('Admin')->where('id', $wo['creater'])->value('mobile') ?: '-'; } $item->content = $wo['content']; $item->remark = $wo['remark']; $item->status = $wo['status']; $solveName = Db::name('Admin')->where('id', $wo['solve'])->value('name'); $item->solve = $solveName ?: '-'; $adminName = Db::name('Admin')->where('id', $wo['creater'])->value('name'); $item->creater = $adminName ?: '-'; $item->sub_time = $wo['sub_time']; $item->create_time = $wo['create_time']; $item->update_time = $wo['update_time']; $item->delete_time = $wo['delete_time']; }) ->filter(function ($item) { return $item->delete_time === null; }); return table_assign(0, '', $list->toArray()); } else { return view(); } } //添加 public function add() { $param = get_params(); // 获取请求参数 $uid = $this->uid; // 当前用户 ID if (request()->isPost()) { // 添加逻辑 $param['creater'] = $uid; // 设置上传用户 $param['create_time'] = date('Y-m-d H:i:s'); // 创建时间 //如果没有sub_time就用当前创建时间 if (empty($param['sub_time'])) { $param['sub_time'] = $param['create_time']; } // 插入数据并获取自增 ID $sid = WorkOrderList::strict(false)->field(true)->insertGetId($param); if ($sid) { // 添加日志 add_log('add', $sid, $param); $log_data = [ 'module' => 'workorder', 'download_id' => $sid, 'new_content' => $param['content'], 'field' => 'new', 'action' => 'add', 'admin_id' => $uid, 'create_time' => time(), ]; Db::name('Log')->strict(false)->field(true)->insert($log_data); return to_assign(0, '添加成功', ['redirect' => 'javascript:history.back()']); } else { return to_assign(1, '添加失败'); } } else { // 非 POST 请求,返回视图 return view(); } } //编辑 public function edit() { if (request()->isPost()) { $param = get_params(); $id = isset($param['id']) ? $param['id'] : 0; $data = [ 'solve' => $param['solve'], 'status' => $param['status'], 'update_time' => date('Y-m-d H:i:s'), ]; $res = WorkOrderList::where('id', $id)->update($data); if ($res) { return to_assign(2, '更新成功!'); } else { return to_assign(1, '更新失败'); } } else { $param = get_params(); $id = isset($param['id']) ? $param['id'] : 0; $workorder = WorkOrderList::where('id', $id) ->field('id, project_id, problemtype, uid, username, contact, content, remark, status, solve, creater, sub_time, create_time') ->find(); if ($workorder) { View::assign('detail', $workorder); } else { View::assign('message', '没有详细数据'); } return view(); } } //查看 public function view() { $param = get_params(); $id = isset($param['id']) ? $param['id'] : 0; if (empty($id)) { return to_assign(1, '参数错误,缺少ID'); } $view = WorkOrderList::where('id', $id)->find(); if ($view) { $projectName = Db::name('Project')->where('id', $view['project_id'])->value('name_short'); $view['project_id'] = $projectName ?: '-'; if (!empty($view['contact'])) { $view->contact = $view['contact']; } else { $view->contact = Db::name('Admin')->where('id', $view['creater'])->value('mobile') ?: '-'; } $adminName = Db::name('Admin')->where('id', $view['creater'])->value('name'); $view->creater = $adminName ?: '-'; $solveName = Db::name('Admin')->where('id', $view['solve'])->value('name'); $view->solve = $solveName ?: '-'; View::assign('view', $view); return view(); } else { return to_assign(1, '信息不存在'); } } //删除 public function delete() { $request = request(); if ($request->isDelete() || $request->isAjax()) { $id = get_params("id"); $detail = WorkOrderList::where('id', $id)->find(); if (WorkOrderList::where('id', $id)->update(['delete_time' => date('Y-m-d H:i:s')]) !== false) { $log_data = array( 'module' => 'WorkOrderList', 'field' => 'delete', 'action' => 'delete', 'admin_id' => $this->uid, 'old_content' => '', 'new_content' => $detail['name'], 'create_time' => time(), ); Db::name('Log')->strict(false)->field(true)->insert($log_data); return to_assign(0, "删除成功"); } else { return to_assign(0, "删除失败"); } } else { return to_assign(1, "错误的请求"); } } //批量删除 public function batch_delete() { $request = request(); if ($request->isDelete() || $request->isAjax()) { $ids = get_params("ids"); foreach ($ids as $id) { $detail = WorkOrderList::where('id', $id)->find(); if (WorkOrderList::where('id', $id)->update(['delete_time' => date('Y-m-d H:i:s')]) !== false) { $log_data = array( 'module' => 'WorkOrderList', 'field' => 'delete', 'action' => 'delete', 'admin_id' => $this->uid, 'old_content' => '', 'new_content' => $detail['name'], 'create_time' => time(), ); Db::name('Log')->strict(false)->field(true)->insert($log_data); } } return to_assign(0, "批量删除成功"); } else { return to_assign(1, "错误的请求"); } } }