param([ 'title', 'banner_id', 'created_at', 'page/d' => 1, 'size/d' => 10 ]); $banner_items = SysBannerItemModel::field([ 'id', 'banner_id', 'title', 'sort', 'created_at' ]) ->with(['banner' => function ($query) { $query->field(['id', 'name' => 'banner_name']); }]) ->withSearch(['title', 'created_at'], [ 'title' => $param['title'] ?? null, 'created_at' => !empty($param['created_at']) ? explode(',', $param['created_at']) : null ]) ->bannerId($param['banner_id'] ?? null) ->order(['sort' => 'asc', 'id' => 'desc']) ->paginate([ 'list_rows' => $param['size'] ?? 10, 'page' => $param['page'] ?? 1 ]) ->bindAttr('banner', ['banner_name']) ->hidden(['banner_id', 'banner']); return success('获取成功', $banner_items); } // 详情 public function read() { $id = request()->param('id'); $banner_item = SysBannerItemModel::withoutField([ 'created_at', 'updated_at', 'deleted_at' ]) ->find($id); if (empty($banner_item)) { return error('横幅不存在'); } return success('获取成功', $banner_item); } // 新增 public function save() { $post = request()->post([ 'banner_id', 'title', 'title_txt_color', 'desc', 'desc_txt_color', 'type', 'image', 'video', 'link_to', 'link', 'sort', 'status' ]); $validate = new SysBannerItemValidate; if (!$validate->scene('add')->check($post)) { return error($validate->getError()); } $banner_item = SysBannerItemModel::create($post); if ($banner_item->isEmpty()) { return error('操作失败'); } return success('操作成功'); } // 修改 public function update() { $id = request()->param('id'); $put = request()->put([ 'banner_id', 'title', 'title_txt_color', 'desc', 'desc_txt_color', 'type', 'image', 'video', 'link_to', 'link', 'sort', 'status' ]); $validate = new SysBannerItemValidate; if (!$validate->check(array_merge($put, ['id' => $id]))) { return error($validate->getError()); } $banner_item = SysBannerItemModel::bypk($id)->find(); if (empty($banner_item)) { return error('请确认操作对象是否存在'); } if (!$banner_item->save($put)) { return error('操作失败'); } return success('操作成功'); } // 设置排序值 public function sort() { $id = request()->param('id'); $sort = request()->param('sort'); $banner_item = SysBannerItemModel::bypk($id)->find(); if (empty($banner_item)) { return error('请确认操作对象是否存在'); } if ($banner_item->sort != $sort) { $banner_item->sort = $sort; if (!$banner_item->save()) { return error('操作失败'); } } return success('操作成功'); } // 导出 public function export() { $schema = [ 'id' => 'ID', 'banner_name' => '分类名称', 'title' => '横幅名称', 'title_txt_color' => '横幅名称字体颜色', 'desc' => '描述', 'desc_txt_color' => '描述字体颜色', 'type' => '前台显示类型', 'image' => '图片地址', 'video' => '视频地址', 'link_to' => '链接类型', 'link' => '链接地址', 'sort' => '排序值', 'status' => '状态', 'created_at' => '添加时间' ]; // 获取要导出的横幅项数据 $banner_items = $this->getBannerExportData(); // 导出 return xlsx_writer($banner_items, $schema); } // 获取导出数据 private function getBannerExportData() { $param = request()->param([ 'title', 'banner_id', 'created_at' ]); return SysBannerItemModel::withoutField([ 'updated_at', 'deleted_at' ]) ->with(['banner' => function ($query) { $query->field(['id', 'name' => 'banner_name']); }]) ->withSearch(['title', 'created_at'], [ 'title' => $param['title'] ?? null, 'created_at' => !empty($param['created_att']) ? explode(',', $param['created_att']) : null, ]) ->bannerId($param['banner_id'] ?? null) ->order(['sort' => 'asc', 'id' => 'desc']) ->select() ->bindAttr('banner', ['banner_name']) ->hidden(['banner_id', 'banner']); } // 删除 public function delete() { $id = request()->param('id'); $banner_item = SysBannerItemModel::bypk($id)->find(); if (empty($banner_item)) { return error('请确认操作对象是否存在'); } if (!$banner_item->delete()) { return error('操作失败'); } return success('操作成功'); } }