// +---------------------------------------------------------------------- namespace App\Services\Common; use App\Models\VideoDatasCategoryModel; use App\Services\BaseService; use App\Services\RedisService; /** * 表单数据分类管理-服务类 * @author laravel开发员 * @since 2020/11/11 * @package App\Services\Common */ class VideosDatasCategoryService extends BaseService { /** * 构造函数 * @author laravel开发员 * @since 2020/11/11 * AdService constructor. */ public function __construct() { $this->model = new VideoDatasCategoryModel(); } /** * 列表 * @param $params * @param int $pageSize * @return array */ public function getDataList($params, $pageSize = 15) { $query = $this->getQuery($params); $list = $query->select(['a.*']) ->orderBy('a.create_time','desc') ->orderBy('a.id','desc') ->paginate($pageSize > 0 ? $pageSize : 9999999); $list = $list? $list->toArray() :[]; if($list){ foreach($list['data'] as &$item){ $item['create_time'] = $item['create_time']? datetime($item['create_time'],'Y-m-d H.i.s') : ''; } } return [ 'pageSize'=> $pageSize, 'total'=>isset($list['total'])? $list['total'] : 0, 'list'=> isset($list['data'])? $list['data'] : [] ]; } /** * 查询 * @param $params * @return \Illuminate\Database\Eloquent\Builder */ public function getQuery($params) { $where = ['a.mark' => 1]; $status = isset($params['status'])? $params['status'] : 1; $attrType = isset($params['attr_type'])? $params['attr_type'] : 2; if($status>0){ $where['a.status'] = $status; }else{ unset($where['a.status']); } if($attrType>0){ $where['a.attr_type'] = $attrType; } $model = $this->model->from('videos_datas_categorys as a') ->where($where) ->where(function ($query) use($params){ $keyword = isset($params['keyword'])? $params['keyword'] : ''; if($keyword){ $query->where(function ($query) use ($keyword){ $query->where('a.name','like',"%{$keyword}%"); }); } }); return $model; } /** * 添加或编辑 * @return array * @since 2020/11/11 * @author laravel开发员 */ public function edit() { $data = request()->all(); // 图片处理 if(isset($data['icon'])){ $data['icon'] = get_image_path($data['icon']); } return parent::edit($data); } /** * 删除七天之前标记软删除的数据 */ public function delete() { $this->model->where('mark', 0)->where('update_time', '<=', time() - 7 * 86400)->delete(); return parent::delete(); } /** * 选项 * @return array */ public function options() { $cacheKey = "caches:videos:dataCategoryList"; $datas = RedisService::get($cacheKey); if($datas){ return $datas; } $datas = $this->model->where(['status'=>1,'mark'=>1]) ->select(['id', 'name', 'icon', 'type', 'attr_type', 'status']) ->orderBy('sort','desc') ->orderBy('id','asc') ->get(); $datas = $datas? $datas->toArray() : []; if($datas){ RedisService::set($cacheKey, $datas, rand(10,20)); } return $datas; } }