// +---------------------------------------------------------------------- namespace App\Services; use App\Models\SignsModel; /** * 打卡签到管理-服务类 * @author wesmiler * @since 2020/11/11 * Class SignsService * @package App\Services */ class SignsService extends BaseService { /** * 构造函数 * @author wesmiler * @since 2020/11/11 * SignsService constructor. */ public function __construct() { $this->model = new SignsModel(); } /** * 获取列表 * @return array * @since 2020/11/11 * @author wesmiler */ public function getList() { $params = request()->all(); $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE; $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE; $dataList = $this->model::from('signs as s') ->leftJoin('sign_cates as sc', 'sc.id', '=', 's.cate_id') ->leftJoin('member as m', 'm.id', '=', 's.user_id') ->where(function ($query) use ($params) { $query->where('s.mark', 1); $type = isset($params['type'])? $params['type'] : 0; if($type>0){ $query->where('s.type', $type); } $status = isset($params['status']) ? $params['status'] : 0; if ($status > 0) { $query->where('s.status', $status); } else { $query->whereIn('s.status', [1, 2]); } }) ->where(function ($query) use ($params) { $keyword = isset($params['keyword']) ? trim($params['keyword']) : ''; if (!empty($keyword)) { $query->where('m.nickname','like',"%{$keyword}%"); } }) ->select(['s.id', 's.user_id','s.cate_id', 'sc.name as cate_name', 'm.nickname', 's.sign_at', 's.type', 's.status', 's.create_time', 's.update_time', 's.description']) ->orderBy('s.sign_at', 'desc') ->orderBy('s.cate_id') ->paginate($pageSize); $dataList = $dataList ? $dataList->toArray() : []; if ($dataList) { foreach ($dataList['data'] as &$item) { $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : ''; } unset($item); } return [ 'code' => 0, 'success'=> true, 'msg' => '操作成功', 'count' => isset($dataList['total']) ? $dataList['total'] : 0, 'data' => isset($dataList['data']) ? $dataList['data'] : 0, ]; } /** * 添加或编辑 * @return array * @since 2020/11/11 * @author wesmiler */ public function edit() { $data = request()->all(); $data['update_time'] = time(); return parent::edit($data); // TODO: Change the autogenerated stub } }