// +---------------------------------------------------------------------- namespace App\Services; use App\Models\ActivityBooksModel; /** * 寺院活动报名管理-服务类 * @author wesmiler * @since 2020/11/11 * Class ActivityBooksService * @package App\Services */ class ActivityBooksService extends BaseService { /** * 构造函数 * @author wesmiler * @since 2020/11/11 * ActivityBooksService constructor. */ public function __construct() { $this->model = new ActivityBooksModel(); } /** * 获取列表 * @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('activity_books as b') ->leftJoin('activity as a', 'a.id', '=', 'b.aid') ->leftJoin('member as m', 'm.id', '=', 'b.user_id') ->where(function ($query) use ($params) { $query->where('b.mark', 1); $status = isset($params['status']) ? $params['status'] : 0; if ($status > 0) { $query->where('b.status', $status); } else { $query->whereIn('b.status', [1, 2]); } }) ->where(function ($query) use ($params) { $keyword = isset($params['keyword']) ? trim($params['keyword']) : ''; if (!empty($keyword)) { $query->where('a.title', 'like', "%{$keyword}%") ->orWhere('b.order_sn','like',"%{$keyword}%") ->orWhere('m.nickname','like',"%{$keyword}%"); } }) ->select(['b.id', 'b.aid', 'a.title', 'm.nickname','b.order_sn','b.coupon','b.coupon_give','b.gd_name','b.xy_content', 'm.avatar', 'b.status', 'b.create_time', 'b.update_time']) ->orderBy('b.update_time', 'desc') ->paginate($pageSize); $dataList = $dataList ? $dataList->toArray() : []; if ($dataList) { foreach ($dataList['data'] as &$item) { $item['avatar'] = $item['avatar'] ? get_image_url($item['avatar']) : ''; $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 getDataList($params) { $page = isset($params['pageSize']) ? intval($params['pageSize']) : PAGE; $pageSize = isset($params['pageSize']) ? intval($params['pageSize']) : PERPAGE; $userId = isset($params['user_id']) ? intval($params['user_id']) : 0; $dataList = $this->model::from('activity_books as b') ->leftJoin('activity as a', 'a.id', '=', 'b.aid') ->leftJoin('member as m', 'm.id', '=', 'b.user_id') ->where(['b.mark'=>1,'a.status'=> 1,'b.user_id'=> $userId,'a.mark'=> 1,'a.status'=> 1]) ->select(['b.id', 'b.aid', 'a.title','b.user_id','a.thumb','b.coupon','b.coupon_give','a.publish_start','a.publish_end','a.price','b.gd_name','a.description', 'b.status', 'b.create_time', 'b.update_time']) ->orderBy('b.update_time', 'desc') ->paginate($pageSize); $dataList = $dataList ? $dataList->toArray() : []; if ($dataList) { foreach ($dataList['data'] as &$item) { $item['coupon'] = intval($item['coupon']); $item['coupon_give'] = intval($item['coupon_give']); $item['thumb'] = $item['thumb'] ? get_image_url($item['thumb']) : ''; $item['create_time'] = $item['create_time'] ? datetime($item['create_time'],'Y-m-d H:i:s') : ''; $publishStart = isset($item['publish_start']) && $item['publish_start']? date('m月d日', strtotime($item['publish_start'])) : ''; $publishEnd = isset($item['publish_end']) && $item['publish_end']? date('m月d日', strtotime($item['publish_end'])) : ''; $item['publish_at'] = $publishStart==$publishEnd? $publishStart : ($publishStart && $publishEnd>$publishStart? $publishStart.'-'.$publishEnd : ''); $item['publish_at_text'] = $item['publish_start'] && $item['publish_end']? $item['publish_start'].'至'.$item['publish_end'] : ''; } 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 } }