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.
272 lines
8.2 KiB
272 lines
8.2 KiB
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | Niucloud-admin 企业快速开发的多应用管理平台
|
|
// +----------------------------------------------------------------------
|
|
// | 官方网址:https://www.niucloud.com
|
|
// +----------------------------------------------------------------------
|
|
// | niucloud团队 版权所有 开源版本可自由商用
|
|
// +----------------------------------------------------------------------
|
|
// | Author: Niucloud Team
|
|
// +----------------------------------------------------------------------
|
|
|
|
namespace app\api\controller\apiController;
|
|
|
|
use app\Request;
|
|
use app\service\api\apiService\CourseScheduleService;
|
|
use core\base\BaseApiService;
|
|
|
|
/**
|
|
* 课程安排相关接口
|
|
* Class CourseSchedule
|
|
* @package app\api\controller\apiController
|
|
*/
|
|
class CourseSchedule extends BaseApiService
|
|
{
|
|
/**
|
|
* 获取课程安排列表
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function getScheduleList(Request $request)
|
|
{
|
|
$data = $request->all();
|
|
return success((new CourseScheduleService())->getScheduleList($data));
|
|
}
|
|
|
|
/**
|
|
* 获取课程安排详情
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function getScheduleInfo(Request $request)
|
|
{
|
|
$data = $this->request->params([
|
|
["id", 0]
|
|
]);
|
|
$result = (new CourseScheduleService())->getScheduleInfo($data['id']);
|
|
if (isset($result['code']) && $result['code'] === 0) {
|
|
return fail($result['msg']);
|
|
}
|
|
return success('SUCCESS', $result);
|
|
}
|
|
|
|
/**
|
|
* 创建课程安排
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function createSchedule(Request $request)
|
|
{
|
|
try {
|
|
$data = $this->request->params([
|
|
["campus_id", 0],
|
|
["venue_id", 0],
|
|
["course_date", ""],
|
|
["time_slot", ""],
|
|
["course_id", 0],
|
|
["coach_id", 0],
|
|
["available_capacity", 0],
|
|
["class_id", 0],
|
|
["remarks", ""],
|
|
["created_by", "manual"]
|
|
]);
|
|
|
|
// 验证必填字段
|
|
$required = ['campus_id', 'venue_id', 'course_date', 'time_slot', 'course_id', 'coach_id', 'available_capacity'];
|
|
foreach ($required as $field) {
|
|
if (empty($data[$field])) {
|
|
return fail("字段 {$field} 不能为空");
|
|
}
|
|
}
|
|
|
|
$result = (new CourseScheduleService())->createCourseSchedule($data);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
return success($result['msg'] ?? '创建成功', $result['data'] ?? []);
|
|
} catch (\Exception $e) {
|
|
return fail('创建课程安排失败:' . $e->getMessage());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 批量创建课程安排
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function batchCreateSchedule(Request $request)
|
|
{
|
|
$data = $request->all();
|
|
$result = (new CourseScheduleService())->batchCreateSchedule($data);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
return success($result['msg'] ?? '批量创建成功', $result['data'] ?? []);
|
|
}
|
|
|
|
/**
|
|
* 更新课程安排
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function updateSchedule(Request $request)
|
|
{
|
|
$data = $request->all();
|
|
$result = (new CourseScheduleService())->updateSchedule($data);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
return success($result['msg'] ?? '更新成功', $result['data'] ?? []);
|
|
}
|
|
|
|
/**
|
|
* 删除课程安排
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function deleteSchedule(Request $request)
|
|
{
|
|
$data = $this->request->params([
|
|
["id", 0]
|
|
]);
|
|
$result = (new CourseScheduleService())->deleteSchedule($data['id']);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
return success($result['msg'] ?? '删除成功');
|
|
}
|
|
|
|
/**
|
|
* 获取场地列表
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function getVenueList(Request $request)
|
|
{
|
|
try {
|
|
$data = $this->request->params([
|
|
["campus_id", 0], // 校区ID筛选
|
|
["keyword", ""], // 场地名称关键词搜索
|
|
["status", 1] // 状态筛选,默认获取可用场地
|
|
]);
|
|
|
|
$result = (new CourseScheduleService())->getVenueListForSchedule($data);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
|
|
return success('获取成功', $result['data']);
|
|
} catch (\Exception $e) {
|
|
return fail('获取场地列表失败:' . $e->getMessage());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 获取场地可用时间
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function getVenueAvailableTime(Request $request)
|
|
{
|
|
try {
|
|
$data = $this->request->params([
|
|
["venue_id", 0],
|
|
["date", ""]
|
|
]);
|
|
|
|
if (empty($data['venue_id'])) {
|
|
return fail('场地ID不能为空');
|
|
}
|
|
|
|
if (empty($data['date'])) {
|
|
return fail('查询日期不能为空');
|
|
}
|
|
|
|
$result = (new CourseScheduleService())->getVenueAvailableTimeSlots($data);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
|
|
return success('获取成功', $result['data']);
|
|
} catch (\Exception $e) {
|
|
return fail('获取场地可用时间失败:' . $e->getMessage());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 检查教练时间冲突
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function checkCoachConflict(Request $request)
|
|
{
|
|
$data = $this->request->params([
|
|
["coach_id", 0],
|
|
["date", ""],
|
|
["time_slot", ""],
|
|
["schedule_id", 0] // 排除当前正在编辑的课程安排
|
|
]);
|
|
return success((new CourseScheduleService())->checkCoachConflict($data));
|
|
}
|
|
|
|
/**
|
|
* 获取课程安排统计
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function getScheduleStatistics(Request $request)
|
|
{
|
|
$data = $request->all();
|
|
return success((new CourseScheduleService())->getScheduleStatistics($data));
|
|
}
|
|
|
|
/**
|
|
* 学员加入课程安排
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function joinSchedule(Request $request)
|
|
{
|
|
$data = $this->request->params([
|
|
["schedule_id", 0],
|
|
["student_id", 0],
|
|
["course_type", 0], // 0-正常, 1-加课, 2-补课, 3-等待位
|
|
["resources_id", 0]
|
|
]);
|
|
$result = (new CourseScheduleService())->joinSchedule($data);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
return success($result['msg'] ?? '添加成功', $result['data'] ?? []);
|
|
}
|
|
|
|
/**
|
|
* 学员退出课程安排
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function leaveSchedule(Request $request)
|
|
{
|
|
$data = $this->request->params([
|
|
["schedule_id", 0],
|
|
["student_id", 0],
|
|
["remark", ""]
|
|
]);
|
|
$result = (new CourseScheduleService())->leaveSchedule($data);
|
|
if (!$result['code']) {
|
|
return fail($result['msg']);
|
|
}
|
|
return success($result['msg'] ?? '操作成功');
|
|
}
|
|
|
|
/**
|
|
* 获取筛选选项
|
|
* @param Request $request
|
|
* @return \think\Response
|
|
*/
|
|
public function getFilterOptions(Request $request)
|
|
{
|
|
$data = $request->all();
|
|
return success((new CourseScheduleService())->getFilterOptions($data));
|
|
}
|
|
}
|