267 lines
8.0 KiB
PHP
267 lines
8.0 KiB
PHP
<?php
|
|
declare (strict_types = 1);
|
|
|
|
namespace app\admin\controller\v1;
|
|
|
|
use app\admin\model\v1\ArticleModel;
|
|
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
|
|
]);
|
|
|
|
$banner_items = SysBannerItemModel::alias('item')
|
|
->field([
|
|
'item.id',
|
|
'item.title',
|
|
'item.image',
|
|
'item.sort',
|
|
'item.created_at',
|
|
'banner.name' => 'banner_name'
|
|
])
|
|
->join('sys_banner banner', 'banner.id = item.banner_id')
|
|
->where('banner.language_id', '=', request()->lang_id)
|
|
->where(function($query) use($param){
|
|
if (!empty($param['banner_id'])) {
|
|
$query->where('item.banner_id', '=', $param['banner_id']);
|
|
}
|
|
if (!empty($param['title'])) {
|
|
$query->where('item.title', 'like', "%{$param['title']}%");
|
|
}
|
|
if (!empty($param['created_at'])) {
|
|
$value = explode(',', $param['created_at']);
|
|
if (count($value) > 1) {
|
|
if ($value[1] == $value[0]) {
|
|
$value[1] = date('Y-m-d 23:59:59', strtotime($value[1]));
|
|
}
|
|
$query->whereBetweenTime('item.created_at', $value[0], $value[1]);
|
|
} else {
|
|
$query->whereTime('item.created_at', '>=', $value[0]);
|
|
}
|
|
}
|
|
})
|
|
->order(['item.sort' => 'asc', 'item.id' => 'desc'])
|
|
->paginate([
|
|
'list_rows' => $param['size'],
|
|
'page' => $param['page']
|
|
]);
|
|
|
|
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('横幅不存在');
|
|
}
|
|
|
|
// 组装用于前台回显的链接数据
|
|
$banner_item['link_echo_data'] = System::getEchoDataBySystemPageUrl($banner_item['link_to'], $banner_item['link']);
|
|
|
|
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' => 'custom',
|
|
'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 ($put['type'] == 'video') {
|
|
unset($put['link']);
|
|
unset($put['link_to']);
|
|
}
|
|
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::alias('item')
|
|
->field([
|
|
'item.id',
|
|
'banner.name' => 'banner_name',
|
|
'item.title',
|
|
'item.title_txt_color',
|
|
'item.desc',
|
|
'item.desc_txt_color',
|
|
'item.type',
|
|
'item.image',
|
|
'item.video',
|
|
'item.link_to',
|
|
'item.link',
|
|
'item.sort' ,
|
|
'item.status',
|
|
'item.created_at'
|
|
])
|
|
->join('sys_banner banner', 'banner.id = item.banner_id')
|
|
->where('banner.language_id', '=', request()->lang_id)
|
|
->where(function($query) use($param){
|
|
if (!empty($param['banner_id'])) {
|
|
$query->where('item.banner_id', '=', $param['banner_id']);
|
|
}
|
|
if (!empty($param['title'])) {
|
|
$query->where('item.title', 'like', "%{$param['title']}%");
|
|
}
|
|
if (!empty($param['created_at'])) {
|
|
$value = explode(',', $param['created_at']);
|
|
if (count($value) > 1) {
|
|
if ($value[1] == $value[0]) {
|
|
$value[1] = date('Y-m-d 23:59:59', strtotime($value[1]));
|
|
}
|
|
$query->whereBetweenTime('item.created_at', $value[0], $value[1]);
|
|
} else {
|
|
$query->whereTime('item.created_at', '>=', $value[0]);
|
|
}
|
|
}
|
|
})
|
|
->order(['item.sort' => 'asc', 'item.id' => 'desc'])
|
|
->select();
|
|
}
|
|
|
|
// 删除
|
|
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('操作成功');
|
|
}
|
|
}
|