|  |  | <?php
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  | namespace App\Http\Controllers\Admin;
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  | use App\Exports\BaseExport;
 | 
						
						
						
							|  |  | use App\Helpers\ResponseCode;
 | 
						
						
						
							|  |  | use App\Models\AppointmentType;
 | 
						
						
						
							|  |  | use App\Models\CustomForm;
 | 
						
						
						
							|  |  | use App\Models\SupplyDemand;
 | 
						
						
						
							|  |  | use App\Models\SupplyDemandType;
 | 
						
						
						
							|  |  | use Illuminate\Support\Facades\Validator;
 | 
						
						
						
							|  |  | use Maatwebsite\Excel\Facades\Excel;
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  | class SupplyDemandController extends BaseController
 | 
						
						
						
							|  |  | {
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  |     /**
 | 
						
						
						
							|  |  |      * 构造函数
 | 
						
						
						
							|  |  |      */
 | 
						
						
						
							|  |  |     public function __construct()
 | 
						
						
						
							|  |  |     {
 | 
						
						
						
							|  |  |         parent::__construct(new SupplyDemand());
 | 
						
						
						
							|  |  |     }
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  |     /**
 | 
						
						
						
							|  |  |      * @OA\Get(
 | 
						
						
						
							|  |  |      *     path="/api/admin/supply-demand/index",
 | 
						
						
						
							|  |  |      *     tags={"供需信息管理"},
 | 
						
						
						
							|  |  |      *     summary="列表",
 | 
						
						
						
							|  |  |      *     description="",
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="is_export", in="query", @OA\Schema(type="string"), required=false, description="是否导出0否1是"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="export_fields", in="query", @OA\Schema(type="string"), required=false, description="需要导出的字段数组"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="filter", in="query", @OA\Schema(type="string"), required=false, description="查询条件。数组"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="show_relation", in="query", @OA\Schema(type="string"), required=false, description="需要输出的关联关系数组,包括:teacher,courseSettings,coursePeriods"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="page_size", in="query", @OA\Schema(type="string"), required=false, description="每页显示的条数"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="page", in="query", @OA\Schema(type="string"), required=false, description="页码"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="sort_name", in="query", @OA\Schema(type="string"), required=false, description="排序字段名字"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="sort_type", in="query", @OA\Schema(type="string"), required=false, description="排序类型"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
 | 
						
						
						
							|  |  |      *     @OA\Response(
 | 
						
						
						
							|  |  |      *      response="200",
 | 
						
						
						
							|  |  |      *      description="暂无"
 | 
						
						
						
							|  |  |      *     )
 | 
						
						
						
							|  |  |      * )
 | 
						
						
						
							|  |  |      */
 | 
						
						
						
							|  |  |     public function index()
 | 
						
						
						
							|  |  |     {
 | 
						
						
						
							|  |  |         $all = request()->all();
 | 
						
						
						
							|  |  |         $list = $this->model->with('user')->where(function ($query) use ($all) {
 | 
						
						
						
							|  |  |             if (isset($all['filter']) && !empty($all['filter'])) {
 | 
						
						
						
							|  |  |                 foreach ($all['filter'] as $condition) {
 | 
						
						
						
							|  |  |                     $key = $condition['key'] ?? null;
 | 
						
						
						
							|  |  |                     $op = $condition['op'] ?? null;
 | 
						
						
						
							|  |  |                     $value = $condition['value'] ?? null;
 | 
						
						
						
							|  |  |                     if (!isset($key) || !isset($op) || !isset($value)) {
 | 
						
						
						
							|  |  |                         continue;
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 等于
 | 
						
						
						
							|  |  |                     if ($op == 'eq') {
 | 
						
						
						
							|  |  |                         $query->where($key, $value);
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 不等于
 | 
						
						
						
							|  |  |                     if ($op == 'neq') {
 | 
						
						
						
							|  |  |                         $query->where($key, '!=', $value);
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 大于
 | 
						
						
						
							|  |  |                     if ($op == 'gt') {
 | 
						
						
						
							|  |  |                         $query->where($key, '>', $value);
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 大于等于
 | 
						
						
						
							|  |  |                     if ($op == 'egt') {
 | 
						
						
						
							|  |  |                         $query->where($key, '>=', $value);
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 小于
 | 
						
						
						
							|  |  |                     if ($op == 'lt') {
 | 
						
						
						
							|  |  |                         $query->where($key, '<', $value);
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 小于等于
 | 
						
						
						
							|  |  |                     if ($op == 'elt') {
 | 
						
						
						
							|  |  |                         $query->where($key, '<=', $value);
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 模糊搜索
 | 
						
						
						
							|  |  |                     if ($op == 'like') {
 | 
						
						
						
							|  |  |                         $query->where($key, 'like', '%' . $value . '%');
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 否定模糊搜索
 | 
						
						
						
							|  |  |                     if ($op == 'notlike') {
 | 
						
						
						
							|  |  |                         $query->where($key, 'not like', '%' . $value . '%');
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                     // 范围搜索
 | 
						
						
						
							|  |  |                     if ($op == 'range') {
 | 
						
						
						
							|  |  |                         list($from, $to) = explode(',', $value);
 | 
						
						
						
							|  |  |                         if (empty($from) || empty($to)) {
 | 
						
						
						
							|  |  |                             continue;
 | 
						
						
						
							|  |  |                         }
 | 
						
						
						
							|  |  |                         $query->whereBetween($key, [$from, $to]);
 | 
						
						
						
							|  |  |                     }
 | 
						
						
						
							|  |  |                 }
 | 
						
						
						
							|  |  |             }
 | 
						
						
						
							|  |  |         })->orderBy($all['sort_name'] ?? 'id', $all['sort_type'] ?? 'desc');
 | 
						
						
						
							|  |  |         if (isset($all['is_export']) && !empty($all['is_export'])) {
 | 
						
						
						
							|  |  |             $list = $list->get()->toArray();
 | 
						
						
						
							|  |  |             $export_fields = $all['export_fields'] ?? [];
 | 
						
						
						
							|  |  |             // 导出文件名字
 | 
						
						
						
							|  |  |             $tableName = $this->model->getTable();
 | 
						
						
						
							|  |  |             $filename = (new CustomForm())->getTableComment($tableName);
 | 
						
						
						
							|  |  |             return Excel::download(new BaseExport($export_fields, $list, $tableName), $filename . date('YmdHis') . '.xlsx');
 | 
						
						
						
							|  |  |         } else {
 | 
						
						
						
							|  |  |             // 输出
 | 
						
						
						
							|  |  |             $list = $list->paginate($all['page_size'] ?? 20);
 | 
						
						
						
							|  |  |         }
 | 
						
						
						
							|  |  |         return $this->success($list);
 | 
						
						
						
							|  |  |     }
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  |     /**
 | 
						
						
						
							|  |  |      * @OA\Get(
 | 
						
						
						
							|  |  |      *     path="/api/admin/supply-demand/show",
 | 
						
						
						
							|  |  |      *     tags={"供需信息管理"},
 | 
						
						
						
							|  |  |      *     summary="详情",
 | 
						
						
						
							|  |  |      *     description="",
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="id", in="query", @OA\Schema(type="string"), required=true, description="id"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="show_relation", in="query", @OA\Schema(type="string"), required=false, description="需要输出的关联关系数组,填写输出指定数据"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
 | 
						
						
						
							|  |  |      *     @OA\Response(
 | 
						
						
						
							|  |  |      *      response="200",
 | 
						
						
						
							|  |  |      *      description="暂无"
 | 
						
						
						
							|  |  |      *     )
 | 
						
						
						
							|  |  |      * )
 | 
						
						
						
							|  |  |      */
 | 
						
						
						
							|  |  |     public function show()
 | 
						
						
						
							|  |  |     {
 | 
						
						
						
							|  |  |         $all = \request()->all();
 | 
						
						
						
							|  |  |         $messages = [
 | 
						
						
						
							|  |  |             'id.required' => 'Id必填',
 | 
						
						
						
							|  |  |         ];
 | 
						
						
						
							|  |  |         $validator = Validator::make($all, [
 | 
						
						
						
							|  |  |             'id' => 'required'
 | 
						
						
						
							|  |  |         ], $messages);
 | 
						
						
						
							|  |  |         if ($validator->fails()) {
 | 
						
						
						
							|  |  |             return $this->fail([ResponseCode::ERROR_PARAMETER, implode(',', $validator->errors()->all())]);
 | 
						
						
						
							|  |  |         }
 | 
						
						
						
							|  |  |         $detail = $this->model->with('user')->find($all['id']);
 | 
						
						
						
							|  |  |         return $this->success($detail);
 | 
						
						
						
							|  |  |     }
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  |     /**
 | 
						
						
						
							|  |  |      * @OA\Post(
 | 
						
						
						
							|  |  |      *     path="/api/admin/supply-demand/save",
 | 
						
						
						
							|  |  |      *     tags={"供需信息管理"},
 | 
						
						
						
							|  |  |      *     summary="更新或新增",
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="id", in="query", @OA\Schema(type="integer"), required=false, description="需求供应表ID(存在则更新,不存在则新增)"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="title", in="query", @OA\Schema(type="string"), required=false, description="标题"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="supply_demand_type_id", in="query", @OA\Schema(type="integer"), required=false, description="分类ID"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="content", in="query", @OA\Schema(type="string"), required=false, description="内容"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="tag", in="query", @OA\Schema(type="string"), required=false, description="标签"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="wechat", in="query", @OA\Schema(type="string"), required=false, description="微信号"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="mobile", in="query", @OA\Schema(type="string"), required=false, description="电话"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="email", in="query", @OA\Schema(type="string"), required=false, description="邮箱"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="status", in="query", @OA\Schema(type="integer"), required=false, description="审核状态(0:待审核;1:通过;2:拒绝)"),
 | 
						
						
						
							|  |  |      *     @OA\Response(
 | 
						
						
						
							|  |  |      *         response=200,
 | 
						
						
						
							|  |  |      *         description="操作成功"
 | 
						
						
						
							|  |  |      *     )
 | 
						
						
						
							|  |  |      * )
 | 
						
						
						
							|  |  |      */
 | 
						
						
						
							|  |  |     public function save()
 | 
						
						
						
							|  |  |     {
 | 
						
						
						
							|  |  |         return parent::save();
 | 
						
						
						
							|  |  |     }
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  |     /**
 | 
						
						
						
							|  |  |      * @OA\Get(
 | 
						
						
						
							|  |  |      *     path="/api/admin/supply-demand/destroy",
 | 
						
						
						
							|  |  |      *     tags={"供需信息管理"},
 | 
						
						
						
							|  |  |      *     summary="删除",
 | 
						
						
						
							|  |  |      *     description="",
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="id", in="query", @OA\Schema(type="string"), required=true, description="id"),
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
 | 
						
						
						
							|  |  |      *     @OA\Response(
 | 
						
						
						
							|  |  |      *      response="200",
 | 
						
						
						
							|  |  |      *      description="暂无"
 | 
						
						
						
							|  |  |      *     )
 | 
						
						
						
							|  |  |      * )
 | 
						
						
						
							|  |  |      */
 | 
						
						
						
							|  |  |     public function destroy()
 | 
						
						
						
							|  |  |     {
 | 
						
						
						
							|  |  |         return parent::destroy();
 | 
						
						
						
							|  |  |     }
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  |     /**
 | 
						
						
						
							|  |  |      * @OA\Get(
 | 
						
						
						
							|  |  |      *     path="/api/admin/supply-demand/chart",
 | 
						
						
						
							|  |  |      *     tags={"供需信息管理"},
 | 
						
						
						
							|  |  |      *     summary="交互统计",
 | 
						
						
						
							|  |  |      *     description="",
 | 
						
						
						
							|  |  |      *     @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
 | 
						
						
						
							|  |  |      *     @OA\Response(
 | 
						
						
						
							|  |  |      *      response="200",
 | 
						
						
						
							|  |  |      *      description="暂无"
 | 
						
						
						
							|  |  |      *     )
 | 
						
						
						
							|  |  |      * )
 | 
						
						
						
							|  |  |      */
 | 
						
						
						
							|  |  |     public function chart()
 | 
						
						
						
							|  |  |     {
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  |     }
 | 
						
						
						
							|  |  | 
 | 
						
						
						
							|  |  | }
 |