You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

66 lines
2.1 KiB

5 years ago
<?php
namespace App\Http\Controllers\Customer;
use App\Http\Controllers\Controller;
use App\Models\Project;
5 years ago
use App\Models\Training;
5 years ago
class PublicController extends Controller
{
/**
* @OA\Get(
* path="/customer/get-projects",
* summary="V2-获取医院列表",
* description="获取医院列表",
* @OA\Response(
* response="200",
* description="获取医院列表",
* )
* )
*/
public function getProjects()
{
$projects = Project::select("id","name","address")->get();
return response()->json($projects->toArray());
}
5 years ago
/**
* @OA\Get(
* path="/customer/get-training-videos",
* summary="V2-获取视频列表",
* description="获取视频列表",
* @OA\Parameter(name="keyword", in="query", @OA\Schema(type="string"), required=false, description="查询关键词"),
* @OA\Parameter(name="page", in="query", @OA\Schema(type="integer"), required=false, description="当前页码默认为1"),
* @OA\Parameter(name="pageLength", in="query", @OA\Schema(type="integer"), required=false, description="每页数量默认为3"),
* @OA\Response(
* response="200",
* description="获取视频列表"
* )
* )
*/
public function getTrainingVideos()
{
$data = (new Training());
if (request()->keyword) {
$keyword = request()->keyword;
$data = $data->where(function ($query) use ($keyword) {
$query
->where("title", "like", "%{$keyword}%")
->orWhereHas("type", function ($query) use ($keyword) {
$query->where("name", "like", "%{$keyword}%");
});
});
}
$pageLength = request()->pageLength ? (int)request()->pageLength : 3;
$data = $data->with(["type"=>function($query) {
$query->select("id","name");
}])->select("id","type_id","poster","video","published_at")->orderBy("published_at")->paginate($pageLength);
return response()->json($data->toArray());
}
5 years ago
5 years ago
}