isAjax()) { $param = get_params(); $folderId = $param['folder'] ?? null; $query = PicbedList::withoutField('') ->where('delete_time', null); // 如果 folderId 存在且不为 'all',则添加条件 if ($folderId === 'all') { $query->whereNull('folder'); } elseif ($folderId) { $query->where('folder', $folderId); } $list = $query->order('id desc')->cursor(); // 处理每个项 $items = []; foreach ($list as $item) { if ($item->delete_time !== null) { continue; } $picbedImage = Db::name('PicbedImages')->where(['id' => $item->id])->find(); if (!ctype_digit($picbedImage['admin_id'])) { $item->admin_name = $picbedImage['admin_id']; } else { $admin = Db::name('Admin')->where(['id' => $picbedImage['admin_id']])->find(); $item->admin_name = $admin ? $admin['name'] : ''; } $item->path = $picbedImage['path']; $item->size = $picbedImage['size']; $item->type = $picbedImage['type']; $item->new_name = $picbedImage['new_name']; $item->create_time = $picbedImage['create_time']; $item->update_time = $picbedImage['update_time']; $item->delete_time = $picbedImage['delete_time']; $items[] = $item; // 收集处理后的项 } return json(['code' => 0, 'msg' => '', 'count' => count($items), 'data' => $items]); } else { return view(); } } //添加 public function add() { // 添加admin_id $param['admin_id'] = $this->uid; $param = get_params(); if (request()->isPost()) { //markdown数据处理 if (isset($param['table-align'])) { unset($param['table-align']); } if (isset($param['docContent-html-code'])) { $param['content'] = $param['docContent-html-code']; $param['md_content'] = $param['docContent-markdown-doc']; unset($param['docContent-html-code']); unset($param['docContent-markdown-doc']); } if (isset($param['ueditorcontent'])) { $param['content'] = $param['ueditorcontent']; $param['md_content'] = ''; } if (!empty($param['id']) && $param['id'] > 0) { $picbed = (new PicbedList())->detail($param['id']); if ($this->uid == $picbed['admin_id']) { try { validate(PicbedCheck::class)->scene('edit')->check($param); } catch (ValidateException $e) { // 验证失败 输出错误信息 return to_assign(1, $e->getError()); } $param['update_time'] = time(); $res = PicbedList::where('id', $param['id'])->strict(false)->field(true)->update($param); if ($res) { add_log('edit', $param['id'], $param, $picbed); } return to_assign(); } else { return to_assign(1, '只有创建人或者负责人才有权限编辑'); } } else { try { validate(PicbedCheck::class)->scene('add')->check($param); } catch (ValidateException $e) { // 验证失败 输出错误信息 return to_assign(1, $e->getError()); } $param['create_time'] = time(); $param['admin_id'] = $this->uid; $sid = PicbedList::strict(false)->field(true)->insertGetId($param); if ($sid) { add_log('add', $sid, $param); $log_data = array( 'module' => 'picbed', 'id' => $sid, 'new_content' => $param['name'], 'field' => 'new', 'action' => 'add', 'admin_id' => $this->uid, 'create_time' => time(), ); Db::name('Log')->strict(false)->field(true)->insert($log_data); } return to_assign(); } } else { $id = isset($param['id']) ? $param['id'] : 0; if ($id > 0) { $detail = (new PicbedList())->detail($id); if (empty($detail)) { return to_assign(1, '1.信息不存在'); } View::assign('detail', $detail); } View::assign('id', $id); return view(); } } //创建文件夹 public function createfolder() { $param = get_params(); if (request()->isPost()) { $param['sort'] = $param['sort'] ?? 0; // 默认排序为 0 if (!empty($param['id']) && $param['id'] > 0) { $createfolder = (new PicbedFolderList())->detail($param['id']); $param['update_time'] = date('Y-m-d H:i:s', time()); $res = PicbedFolderList::where('id', $param['id'])->strict(false)->field(true)->update($param); if ($res) { add_log('edit', $param['id'], $param, $createfolder); } return to_assign(); } else { $param['create_time'] = date('Y-m-d H:i:s', time()); $param['admin_id'] = $this->uid; $sid = PicbedFolderList::strict(false)->field(true)->insertGetId($param); return to_assign(); } } else { $id = isset($param['id']) ? $param['id'] : 0; if ($id > 0) { $detail = (new PicbedList())->detail($id); if (empty($detail)) { return to_assign(1, '1.信息不存在'); } View::assign('detail', $detail); } View::assign('id', $id); return view(); } } //移动图片到文件夹 public function movefolder() { $param = get_params(); if (request()->isPost()) { // 支持批量移动 if (!empty($param['ids']) && is_array($param['ids'])) { $folderId = $param['folder']; // 获取目标文件夹ID foreach ($param['ids'] as $id) { if ($id > 0) { PicbedList::where('id', $id)->strict(false)->update(['folder' => $folderId]); // 更新每个图片的文件夹 } } return to_assign(); // 返回成功响应 } } else { $id = isset($param['id']) ? $param['id'] : 0; if ($id > 0) { $detail = (new PicbedList())->detail($id); if (empty($detail)) { return to_assign(1, '1.信息不存在'); } View::assign('detail', $detail); } View::assign('id', $id); return view(); } } //查看 public function view() { $param = get_params(); $id = isset($param['id']) ? $param['id'] : 0; $detail = (new PicbedList())->detail($id); // print_r($id); if (empty($detail)) { return to_assign(1, '2.信息不存在'); } else { if ($this->uid != $detail['admin_id']) { // 当前登录用户必须是上传者才能查看 return to_assign(1, '您没权限查看该信息'); } $role_uid = [$detail['admin_id'], $detail['director_uid']]; $role_edit = 'edit'; $view_uid = $role_uid; // if (!empty($detail['check_admin_ids'])) { // $view_uid = array_merge($role_uid, explode(",", $detail['check_admin_ids'])); // } if (!in_array($this->uid, $view_uid) && $detail['is_open'] == 1) { return to_assign(1, '您没权限查看该信息'); } $contact_array = Db::name('Businesscontact') ->field('i.id,i.business_id,i.contact,i.post,i.phone,i.email,i.wechat,i.qq,a.name as admin_name') ->alias('i') ->join('Admin a', 'i.admin_id = a.id', 'LEFT') ->join('PicbedImages b', 'i.business_id = b.id', 'LEFT') ->order('i.create_time desc') ->where(array('i.business_id' => $id)) ->where('i.delete_time', null) ->select()->toArray(); $file_array = Db::name('FileInterfix') ->field('i.id,i.topic_id,i.admin_id,f.name,f.filesize,f.filepath,a.name as admin_name') ->alias('i') ->join('File f', 'i.file_id = f.id', 'LEFT') ->join('Admin a', 'i.admin_id = a.id', 'LEFT') ->order('i.create_time desc') ->where(array('i.topic_id' => $id, 'i.module' => 'picbed')) ->select()->toArray(); $link_array = Db::name('LinkInterfix') ->field('i.id,i.topic_id,i.admin_id,i.desc,i.url,a.name as admin_name') ->alias('i') ->join('Admin a', 'i.admin_id = a.id', 'LEFT') ->order('i.create_time desc') ->where(array('i.topic_id' => $id, 'i.module' => 'picbed', 'delete_time' => 0)) ->select()->toArray(); View::assign('detail', $detail); View::assign('contact_array', $contact_array); View::assign('file_array', $file_array); View::assign('link_array', $link_array); View::assign('role_edit', $role_edit); View::assign('id', $id); return view(); } } //删除 public function delete() { $request = request(); if ($request->isDelete() || $request->isAjax()) { $id = get_params("id"); $detail = Db::name('PicbedImages')->where('id', $id)->find(); if ($detail['admin_id'] != $this->uid) { return to_assign(1, "你不是图片的上传人,无权限删除"); } if (Db::name('PicbedImages')->where('id', $id)->update(['delete_time' => time()]) !== false) { $log_data = array( 'module' => 'picbed', '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 = Db::name('PicbedImages')->where('id', $id)->find(); if (Db::name('PicbedImages')->where('id', $id)->update(['delete_time' => date('Y-m-d H:i:s')]) !== false) { $log_data = array( 'module' => 'PicbedImages', '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, "错误的请求"); } } //获取文件夹目录 public function getpicbedfolder() { $folder = PicbedFolderList::field('id, admin_id, name, sort') ->where('delete_time', null) ->where('status', '<>', 2) ->select(); return json(['code' => 0, 'msg' => '', 'data' => $folder]); } // 获取对应文件夹内文件列表 public function getfloderfiles() { $param = get_params(); // 使用 getpicbedfolder 获取的 id 作为 folder_id $folderId = $param['folder_id'] ?? null; if ($folderId) { $files = PicbedList::where('folder', $folderId) ->where('delete_time', null) ->field('name') // 只获取 name 字段 ->select() ->toArray(); // 转换为数组 return json(['code' => 0, 'msg' => '', 'data' => $files]); } else { return json(['code' => 1, 'msg' => '文件夹ID不能为空']); } } }