refactor: 修改横幅数据项接口命名

This commit is contained in:
2025-03-12 14:27:03 +08:00
parent e2980954cd
commit 60bbb34a1b
2 changed files with 20 additions and 16 deletions

View File

@@ -0,0 +1,221 @@
<?php
declare (strict_types = 1);
namespace app\admin\controller\v1;
use app\admin\model\v1\SysBannerItemModel;
use app\admin\validate\v1\SysBannerItemValidate;
/**
* 横幅数据项控制器
*/
class BannerItem
{
// 分页
public function index()
{
$param = request()->param([
'title',
'banner_id',
'created_at',
'page/d' => 1,
'size/d' => 10
]);
$banners = 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)
->paginate([
'list_rows' => $param['size'] ?? 10,
'page' => $param['page'] ?? 1
])
->bindAttr('banner', ['banner_name'])
->hidden(['banner_id', 'banner']);
return success('获取成功', $banners);
}
// 详情
public function read()
{
$id = request()->param('id');
$banner = SysBannerItemModel::withoutField([
'created_at',
'updated_at',
'deleted_at'
])
->find($id);
if (empty($banner)) {
return error('横幅不存在');
}
return success('获取成功', $banner);
}
// 新增
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 = SysBannerItemModel::create($post);
if ($banner->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 = SysBannerItemModel::bypk($id)->find();
if (empty($banner)) {
return error('请确认操作对象是否存在');
}
if (!$banner->save($put)) {
return error('操作失败');
}
return success('操作成功');
}
// 设置排序值
public function sort()
{
$id = request()->param('id');
$sort = request()->param('sort');
$banner = SysBannerItemModel::bypk($id)->find();
if (empty($banner)) {
return error('请确认操作对象是否存在');
}
if ($banner->sort != $sort) {
$banner->sort = $sort;
if (!$banner->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' => '添加时间'
];
// 获取要导出的横幅项数据
$banners = $this->getBannerExportData();
// 导出
return xlsx_writer($banners, $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()
->bindAtt('banner', ['banner_name'])
->hidden(['banner_id', 'banner']);
}
// 删除
public function delete()
{
$id = request()->param('id');
$banner = SysBannerItemModel::bypk($id)->find();
if (empty($banner)) {
return error('请确认操作对象是否存在');
}
if (!$banner->delete()) {
return error('操作失败');
}
return success('操作成功');
}
}