后台学生、教师课表设置,上传接口、老师上传课程作业、查看课程作业
This commit is contained in:
parent
9498626c22
commit
34f4f28512
16
app/api/controller/ParentController.php
Normal file
16
app/api/controller/ParentController.php
Normal file
@ -0,0 +1,16 @@
|
||||
<?php
|
||||
|
||||
namespace app\api\controller;
|
||||
|
||||
use app\BaseController;
|
||||
|
||||
class ParentController extends BaseController
|
||||
{
|
||||
protected $noNeedLogin = ['login'];
|
||||
|
||||
public function login()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
}
|
24
app/api/controller/StudentHomeworkController.php
Normal file
24
app/api/controller/StudentHomeworkController.php
Normal file
@ -0,0 +1,24 @@
|
||||
<?php
|
||||
|
||||
namespace app\api\controller;
|
||||
|
||||
use app\BaseController;
|
||||
use app\common\service\StudentHomeworkService;
|
||||
use support\Request;
|
||||
|
||||
class StudentHomeworkController extends BaseController
|
||||
{
|
||||
|
||||
/**
|
||||
* @desc 获取课程的家庭作业
|
||||
* @param Request $request
|
||||
* @return \support\Response
|
||||
*/
|
||||
public function getSubjectHomework(Request $request)
|
||||
{
|
||||
$service = new StudentHomeworkService();
|
||||
$result = $service->getSubjectHomework($request);
|
||||
return $this->json($result);
|
||||
|
||||
}
|
||||
}
|
19
app/api/controller/SubjectHomeworkController.php
Normal file
19
app/api/controller/SubjectHomeworkController.php
Normal file
@ -0,0 +1,19 @@
|
||||
<?php
|
||||
|
||||
namespace app\api\controller;
|
||||
|
||||
use app\BaseController;
|
||||
use app\common\service\SubjectHomeworkService;
|
||||
use support\Request;
|
||||
use think\Exception;
|
||||
|
||||
class SubjectHomeworkController extends BaseController
|
||||
{
|
||||
|
||||
public function publish(Request $request)
|
||||
{
|
||||
$service = new SubjectHomeworkService();
|
||||
$result = $service->publish($request);
|
||||
return $this->json($result);
|
||||
}
|
||||
}
|
@ -31,7 +31,7 @@ class UploadController extends BaseController
|
||||
public function uploadFile(Request $request)
|
||||
{
|
||||
$service = new UploadService();
|
||||
$res = $service->uploadImg($request->file('image'));
|
||||
$res = $service->uploadFile($request->file('file'));
|
||||
return $this->json($res);
|
||||
}
|
||||
|
||||
|
56
app/common/model/StudentHomework.php
Normal file
56
app/common/model/StudentHomework.php
Normal file
@ -0,0 +1,56 @@
|
||||
<?php
|
||||
|
||||
namespace app\common\model;
|
||||
|
||||
use app\BaseModel;
|
||||
use support\Model;
|
||||
|
||||
/**
|
||||
* wa_student_homework
|
||||
* @property integer $id (主键)
|
||||
* @property integer $student_id 学生
|
||||
* @property integer $teacher_homework_id 家庭作业id
|
||||
* @property integer $teacher_id 教师
|
||||
* @property integer $teacher_schedule_time_id 教师排课id
|
||||
* @property integer $subject_id 课程id
|
||||
* @property string $homework_file_url 家庭作业地址
|
||||
* @property string $homework_file_name 家庭作业文件名称
|
||||
* @property string $homework_version_file_url 新版本家庭作业
|
||||
* @property string $homework_version_file_name 新版本家庭作业文件名称
|
||||
* @property string $feedback_file_url 家庭作业反馈地址
|
||||
* @property string $feedback_file_name 家庭作业反馈文件名称
|
||||
* @property string $feedback_version_file_url 新版家庭作业反馈地址
|
||||
* @property string $feedback_version_file_name 新版家庭作业反馈名称
|
||||
* @property integer $is_publish 是否发布
|
||||
* @property mixed $created_at 创建时间
|
||||
* @property string $update_at 更新时间
|
||||
* @property string $deleted_at
|
||||
*/
|
||||
class StudentHomework extends BaseModel
|
||||
{
|
||||
|
||||
public function student()
|
||||
{
|
||||
return $this->hasOne(Student::class, 'id', 'student_id')->bind([
|
||||
'student_name',
|
||||
'student_account' => 'account'
|
||||
]);
|
||||
}
|
||||
|
||||
public function teacher()
|
||||
{
|
||||
return $this->hasOne(Teacher::class, 'id', 'teacher_id')->bind([
|
||||
'teacher_name',
|
||||
'teacher_account' => 'account'
|
||||
]);
|
||||
}
|
||||
|
||||
public function subject()
|
||||
{
|
||||
return $this->hasOne(Subject::class, 'id', 'subject_id')->bind([
|
||||
'teacher_name',
|
||||
'teacher_account' => 'account'
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
27
app/common/model/SubjectHomework.php
Normal file
27
app/common/model/SubjectHomework.php
Normal file
@ -0,0 +1,27 @@
|
||||
<?php
|
||||
|
||||
namespace app\common\model;
|
||||
|
||||
use app\BaseModel;
|
||||
use support\Model;
|
||||
|
||||
/**
|
||||
* wa_teacher_homework
|
||||
* @property integer $id (主键)
|
||||
* @property integer $teacher_id 教师
|
||||
* @property integer $teacher_schedule_time_id 教师排课id
|
||||
* @property integer $subject_id 课程id
|
||||
* @property string $homework_file_url 家庭作业地址
|
||||
* @property string $homework_file_name 家庭作业文件名称
|
||||
* @property string $homework_version_file_url 新版本家庭作业
|
||||
* @property string $homework_version_file_name 新版本家庭作业文件名称
|
||||
* @property integer $is_publish 是否发布
|
||||
* @property mixed $created_at 创建时间
|
||||
* @property string $update_at 更新时间
|
||||
* @property string $deleted_at
|
||||
*/
|
||||
class SubjectHomework extends BaseModel
|
||||
{
|
||||
|
||||
|
||||
}
|
@ -30,4 +30,13 @@ class TeacherFreeTime extends BaseModel
|
||||
return $this->hasOne(Teacher::class,'id','teacher_id')->bind(['teacher_name','teacher_account'=>"account"]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @desc 教师排课时间
|
||||
* @return \think\model\relation\HasMany
|
||||
*/
|
||||
public function teacherScheduleTime()
|
||||
{
|
||||
return $this->hasMany(TeacherScheduleTime::class,'free_time_id','id');
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -43,4 +43,14 @@ class TeacherScheduleTime extends BaseModel
|
||||
return $this->hasOne(Subject::class, 'id', 'subject_id');
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @desc 安排学生
|
||||
* @return \think\model\relation\HasMany
|
||||
*/
|
||||
public function studentSchedule()
|
||||
{
|
||||
return $this->hasMany(StudentSchedule::class, 'teacher_schedule_time_id', 'id');
|
||||
}
|
||||
|
||||
}
|
||||
|
45
app/common/service/StudentHomeworkService.php
Normal file
45
app/common/service/StudentHomeworkService.php
Normal file
@ -0,0 +1,45 @@
|
||||
<?php
|
||||
|
||||
namespace app\common\service;
|
||||
|
||||
use app\common\model\StudentHomework;
|
||||
use think\Exception;
|
||||
|
||||
class StudentHomeworkService
|
||||
{
|
||||
|
||||
/**
|
||||
* @desc 获取学生的课程作业
|
||||
* @param $request
|
||||
* @return array|void
|
||||
*/
|
||||
public function getSubjectHomework($request)
|
||||
{
|
||||
try {
|
||||
$data = $request->get();
|
||||
$homework = StudentHomework::where(['teacher_schedule_time_id' => $data['teacher_schedule_time_id']])->order('id asc');
|
||||
$page = isset($data['page']) ? $data['page'] : 1;
|
||||
$limit = isset($data['limit']) ? $data['limit'] : 10;
|
||||
$total = $homework->count();
|
||||
|
||||
$list = $homework->page($page, $limit)->bind(['student', 'subject'])->select();
|
||||
|
||||
return [
|
||||
'code' => ResponseCode::SUCCESS,
|
||||
'data' => [
|
||||
'list' => $list,
|
||||
'total' => $total,
|
||||
'page' => $page,
|
||||
],
|
||||
'msg' => 'success'
|
||||
];
|
||||
|
||||
} catch (Exception $e) {
|
||||
return [
|
||||
'code' => ResponseCode::FAIL,
|
||||
'msg' => $e->getMessage()
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
}
|
63
app/common/service/SubjectHomeworkService.php
Normal file
63
app/common/service/SubjectHomeworkService.php
Normal file
@ -0,0 +1,63 @@
|
||||
<?php
|
||||
|
||||
namespace app\common\service;
|
||||
|
||||
use app\common\model\SubjectHomework;
|
||||
use app\common\model\Teacher;
|
||||
use app\common\model\TeacherScheduleTime;
|
||||
use app\constant\ResponseCode;
|
||||
use think\Exception;
|
||||
|
||||
class SubjectHomeworkService
|
||||
{
|
||||
|
||||
/**
|
||||
* @desc 发布课程作业
|
||||
* @param $request
|
||||
* @return array|void
|
||||
*/
|
||||
public function publish($request)
|
||||
{
|
||||
try {
|
||||
if (empty($request->teacher)) {
|
||||
throw new Exception('请教师登陆后再设置');
|
||||
}
|
||||
$teacher = Teacher::where(['id' => $request->teacher->id])->findOrEmpty();
|
||||
|
||||
if ($teacher->isEmpty()) {
|
||||
throw new Exception('未找到教师信息,设置失败');
|
||||
}
|
||||
$data = $request->post();
|
||||
$teacher_schedule_time = TeacherScheduleTime::where(['id'=> $data['teacher_schedule_time_id']])->findOrEmpty();
|
||||
|
||||
if($teacher_schedule_time->isEmpty()){
|
||||
throw new Exception('未找到教师课程安排');
|
||||
}
|
||||
|
||||
$subject_homework = SubjectHomework::where(['teacher_id' => $teacher->id, 'teacher_schedule_time_id' => $data['teacher_schedule_time_id'], 'subject_id' => $data['subject_id']])->findOrEmpty();
|
||||
|
||||
if(!$subject_homework->isEmpty()){
|
||||
throw new Exception('家庭作业已存在,请勿重复提交');
|
||||
}
|
||||
|
||||
$res = SubjectHomework::create([
|
||||
'teacher_id' => $teacher->id,
|
||||
'teacher_schedule_time_id' => $data['teacher_schedule_time_id'],
|
||||
'subject_id' => $teacher_schedule_time->subject_id,
|
||||
'homework_file_url' => $data['homework_file_url'],
|
||||
'homework_file_name' => $data['homework_file_name'],
|
||||
]);
|
||||
|
||||
return [
|
||||
'code' => ResponseCode::SUCCESS,
|
||||
'msg' => '操作成功'
|
||||
];
|
||||
} catch (Exception $e) {
|
||||
return [
|
||||
'code' => ResponseCode::FAIL,
|
||||
'msg' => $e->getMessage()
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
}
|
@ -43,7 +43,7 @@ class TeacherFreeTimeService
|
||||
foreach ($free_time as $free_date => $times) {
|
||||
if ($times) {
|
||||
foreach ($times as $time) {
|
||||
$time_period = explode('-', $time);
|
||||
$time_period = explode(' - ', $time);
|
||||
$firstDate = new DateTime($free_date . ' ' . trim($time_period[0]));
|
||||
$secondDate = new DateTime($free_date . ' ' . trim($time_period[1]));
|
||||
$diff = $secondDate->diff($firstDate);
|
||||
|
@ -37,7 +37,7 @@ class TeacherScheduleTimeService
|
||||
foreach ($free_time as $free_date => $times) {
|
||||
if ($times) {
|
||||
foreach ($times as $time) {
|
||||
$time_period = explode('-', $time);
|
||||
$time_period = explode( ' - ' , $time);
|
||||
$firstDate = new DateTime($free_date . ' ' . $time_period[0]);
|
||||
$secondDate = new DateTime($free_date . ' ' . $time_period[1]);
|
||||
$diff = $secondDate->diff($firstDate);
|
||||
|
@ -67,12 +67,13 @@ class UploadService
|
||||
|
||||
if ($file && $file->isValid()) {
|
||||
$ext = $file->getUploadExtension();
|
||||
if (in_array($ext, ['jpg', 'jpeg', 'png', 'gif', 'bmp', 'JPG', 'JPEG', 'PBG'])) {
|
||||
$type = 'images';
|
||||
if (in_array($ext, ['pdf', 'doc', 'docx', 'xlsx', 'xls', 'csv', 'pptx', 'ppt', 'zip', 'jpg', 'jpeg', 'png', 'gif', 'bmp', 'JPG', 'JPEG', 'PBG'])) {
|
||||
$type = 'files';
|
||||
} else {
|
||||
$type = 'other';
|
||||
}
|
||||
$fileSize = $file->getSize();
|
||||
$origin_name = $file->getUploadName();
|
||||
|
||||
$uploadDir = '/files/' . $type . '/' . date('Ym') . '/';
|
||||
$filename = date('YmdHis') . rand(999, 99999);
|
||||
@ -91,12 +92,16 @@ class UploadService
|
||||
if ($res['code'] == ResponseCode::FAIL) {
|
||||
throw new Exception($res['msg']);
|
||||
}
|
||||
|
||||
//删除本地图片
|
||||
unlink($filePath);
|
||||
return [
|
||||
'code' => ResponseCode::SUCCESS,
|
||||
'msg' => '上传成功',
|
||||
'data' => $res['data']
|
||||
'data' => [
|
||||
'url' => $res['data'],
|
||||
'origin_name' => $origin_name
|
||||
]
|
||||
];
|
||||
} else {
|
||||
throw new Exception('文件无效');
|
||||
|
@ -258,7 +258,7 @@ class StudentScheduleController extends Crud
|
||||
->select()
|
||||
->toArray();
|
||||
|
||||
$free_time = [];
|
||||
$schedule_time = [];
|
||||
foreach ($list as $item) {
|
||||
$time_period = explode('-', $item['time']);
|
||||
if ($item['subject_id']) {
|
||||
@ -272,17 +272,17 @@ class StudentScheduleController extends Crud
|
||||
$color = 'red';
|
||||
$title = $item['time'];
|
||||
}
|
||||
$free_time[] = [
|
||||
'free_time_id' => $item['id'],
|
||||
$schedule_time[] = [
|
||||
'schedule_time_id' => $item['id'],
|
||||
'title' => $title,
|
||||
'start' => $item['date'] . ' ' . $time_period[0],
|
||||
'start' => $item['date'] . ' ' . trim($time_period[0]),
|
||||
'color' => $color,
|
||||
];
|
||||
}
|
||||
|
||||
return json([
|
||||
'code' => ResponseCode::WEB_API_SUCCESS,
|
||||
'data' => $free_time,
|
||||
'data' => $schedule_time,
|
||||
'msg' => 'success'
|
||||
]);
|
||||
} catch (Exception $e) {
|
||||
@ -293,4 +293,54 @@ class StudentScheduleController extends Crud
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @desc 设置学生排课
|
||||
* @param Request $request
|
||||
* @return Response
|
||||
*/
|
||||
public function studentScheduleTimeSet(Request $request)
|
||||
{
|
||||
|
||||
$data = $request->get();
|
||||
$schedule_time = \app\common\model\StudentSchedule::where(['id'=>$data['schedule_time_id']])->with(['teacher', 'subject', 'student'])->findOrEmpty()->toArray();
|
||||
|
||||
return view('student/schedule_time_setting', ['schedule_time' => $schedule_time]);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @desc 更改学生排课信息
|
||||
* @param Request $request
|
||||
* @return Response
|
||||
*/
|
||||
public function changeScheduleData(Request $request)
|
||||
{
|
||||
try {
|
||||
$data = $request->post();
|
||||
$teacher_schedule_time = \app\common\model\StudentSchedule::where(['id' => $data['schedule_time_id']])->findOrEmpty();
|
||||
if ($teacher_schedule_time->isEmpty()) {
|
||||
throw new Exception('未找到排课时间');
|
||||
}
|
||||
$changeData = [];
|
||||
if(isset($data['is_publish'])){
|
||||
$teacher_schedule_time->is_publish = $data['is_publish'];
|
||||
}
|
||||
|
||||
$teacher_schedule_time->save();
|
||||
|
||||
return json([
|
||||
'code' => ResponseCode::WEB_API_SUCCESS,
|
||||
'data' => [],
|
||||
'msg' => 'success'
|
||||
]);
|
||||
}catch (Exception $e) {
|
||||
return json([
|
||||
'code' => ResponseCode::WEB_API_FAIL,
|
||||
'data' => [],
|
||||
'msg' => 'success'
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -6,6 +6,7 @@ use app\common\model\Student;
|
||||
use app\common\model\StudentSchedule;
|
||||
use app\common\model\Subject;
|
||||
use app\common\model\Teacher;
|
||||
use app\common\model\TeacherScheduleTime;
|
||||
use app\constant\ResponseCode;
|
||||
use support\Request;
|
||||
use support\Response;
|
||||
@ -187,18 +188,23 @@ class TeacherFreeTimeController extends Crud
|
||||
$end_date = date('Y-m-d 23:59:59', strtotime($request->post('end_date')));
|
||||
$list = \app\common\model\TeacherFreeTime::where(['teacher_id' => $teacher_id])
|
||||
->whereBetweenTime('start_time', $start_date, $end_date)
|
||||
// ->with(['subject'])
|
||||
->with(['teacherScheduleTime'])
|
||||
->select()
|
||||
->toArray();
|
||||
|
||||
|
||||
$free_time = [];
|
||||
foreach ($list as $item) {
|
||||
$title = $item['time'] . ' - ' . $item['hour'] . '/h';
|
||||
$title = $item['time'] . '-' . $item['hour'] . '/h';
|
||||
$color = 'red';
|
||||
if(isset($item['teacherScheduleTime']) && !empty($item['teacherScheduleTime'])){
|
||||
$color = 'green';
|
||||
}
|
||||
$free_time[] = [
|
||||
'free_time_id' => $item['id'],
|
||||
'title' => $title,
|
||||
'start' => date('Y-m-d H:i', strtotime($item['start_time'])),
|
||||
'color' => 'green',
|
||||
'color' => $color,
|
||||
];
|
||||
}
|
||||
|
||||
@ -242,10 +248,13 @@ class TeacherFreeTimeController extends Crud
|
||||
|
||||
$time_period = explode(' - ', $free_time['time']);
|
||||
$limit_time = [
|
||||
'start_time' => date('H:i:s', strtotime($time_period[0])),
|
||||
'end_time' => date('H:i:s', strtotime($time_period[1])),
|
||||
'start_time' => date('H:i', strtotime($time_period[0])),
|
||||
'end_time' => date('H:i', strtotime($time_period[1])),
|
||||
];
|
||||
|
||||
//获取已排课时间
|
||||
$teacher_schedule_time = TeacherScheduleTime::where(['free_time_id' => $free_time_id])->select()->toArray();
|
||||
|
||||
|
||||
// $student_schedule = StudentSchedule::where(['teacher_schedule_time_id' => $free_time_id])->select()->toArray();
|
||||
// $student_schedule_id = [];
|
||||
@ -254,7 +263,8 @@ class TeacherFreeTimeController extends Crud
|
||||
// }
|
||||
|
||||
return view('teacher/free_time_setting', [
|
||||
'schedule_time' => $free_time,
|
||||
'free_time' => $free_time,
|
||||
'teacher_schedule_time' => $teacher_schedule_time,
|
||||
'project' => $project,
|
||||
'student' => $student,
|
||||
'limit_time' => $limit_time,
|
||||
|
@ -107,6 +107,12 @@ class TeacherScheduleTimeController extends Crud
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @desc 添加教师排课时间
|
||||
* @param Request $request
|
||||
* @return Response
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function addTeacherScheduleTime(Request $request)
|
||||
{
|
||||
try {
|
||||
@ -138,7 +144,7 @@ class TeacherScheduleTimeController extends Crud
|
||||
$h = $diff->h;
|
||||
$m = round($diff->i / 60, 2);
|
||||
$hour = round($h + $m, 2);
|
||||
$time = $time_period[0] . ' - ' . $time_period[1];
|
||||
$time = trim($time_period[0]) . ' - ' . trim($time_period[1]);
|
||||
|
||||
\app\common\model\TeacherScheduleTime::create([
|
||||
'teacher_id' => $free_time->teacher_id,
|
||||
@ -176,12 +182,14 @@ class TeacherScheduleTimeController extends Crud
|
||||
return parent::update($request);
|
||||
}
|
||||
$teacher = [];
|
||||
|
||||
$init_date = '';
|
||||
if ($request->get('id')) {
|
||||
$teacher_free_time = \app\common\model\TeacherScheduleTime::where(['id' => $request->get('id')])->findOrEmpty();
|
||||
$teacher = Teacher::where(['id' => $teacher_free_time->teacher_id])->field('id,teacher_name,account')->findOrEmpty()->toArray();
|
||||
$teacher_schedule_time = \app\common\model\TeacherScheduleTime::where(['id' => $request->get('id')])->findOrEmpty();
|
||||
$init_date = $teacher_schedule_time->date;
|
||||
$teacher = Teacher::where(['id' => $teacher_schedule_time->teacher_id])->field('id,teacher_name,account')->findOrEmpty()->toArray();
|
||||
}
|
||||
return view('teacher-schedule-time/update', ['teacher' => $teacher]);
|
||||
|
||||
return view('teacher-schedule-time/update', ['teacher' => $teacher, 'init_date' => $init_date]);
|
||||
}
|
||||
|
||||
|
||||
@ -198,11 +206,12 @@ class TeacherScheduleTimeController extends Crud
|
||||
$end_date = date('Y-m-d 23:59:59', strtotime($request->post('end_date')));
|
||||
$list = \app\common\model\TeacherScheduleTime::where(['teacher_id' => $teacher_id])
|
||||
->whereBetweenTime('start_time', $start_date, $end_date)
|
||||
->with(['subject'])
|
||||
->with(['subject', 'studentSchedule'])
|
||||
->select()
|
||||
->toArray();
|
||||
|
||||
$free_time = [];
|
||||
|
||||
$schedule_time = [];
|
||||
foreach ($list as $item) {
|
||||
$time_period = explode('-', $item['time']);
|
||||
if ($item['subject_id']) {
|
||||
@ -216,17 +225,92 @@ class TeacherScheduleTimeController extends Crud
|
||||
$color = 'red';
|
||||
$title = $item['time'];
|
||||
}
|
||||
$free_time[] = [
|
||||
'free_time_id' => $item['id'],
|
||||
$schedule_time[] = [
|
||||
'schedule_time_id' => $item['id'],
|
||||
'title' => $title,
|
||||
'start' => $item['date'] . ' ' . $time_period[0],
|
||||
'start' => $item['date'] . ' ' . trim($time_period[0]),
|
||||
'color' => $color,
|
||||
];
|
||||
}
|
||||
|
||||
return json([
|
||||
'code' => ResponseCode::WEB_API_SUCCESS,
|
||||
'data' => $free_time,
|
||||
'data' => $schedule_time,
|
||||
'msg' => 'success'
|
||||
]);
|
||||
} catch (Exception $e) {
|
||||
return json([
|
||||
'code' => ResponseCode::WEB_API_FAIL,
|
||||
'msg' => $e->getMessage()
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 更新
|
||||
* @param Request $request
|
||||
* @return Response
|
||||
* @throws BusinessException
|
||||
*/
|
||||
public function scheduleTimeSet(Request $request): Response
|
||||
{
|
||||
if ($request->method() === 'POST') {
|
||||
|
||||
if ($request->post('is_publish')) {
|
||||
$request->post('is_publish', 0);
|
||||
}
|
||||
// parent::update($request);
|
||||
|
||||
return parent::update($request);
|
||||
}
|
||||
$schedule_time_id = $request->get('schedule_time_id');
|
||||
$schedule_time = \app\common\model\TeacherScheduleTime::where(['id' => $schedule_time_id])->with(['teacher'])->findOrEmpty()->toArray();
|
||||
//课程
|
||||
$project = Subject::order('sort desc, id asc')->select()->toArray();
|
||||
//所有学生
|
||||
$student = Student::order('id asc')->field('id,account,student_name')->select()->toArray();
|
||||
$student_schedule = StudentSchedule::where(['teacher_schedule_time_id' => $schedule_time_id])->select()->toArray();
|
||||
$student_schedule_id = [];
|
||||
if ($student_schedule) {
|
||||
$student_schedule_id = array_column($student_schedule, 'student_id');
|
||||
}
|
||||
|
||||
return view('teacher-schedule-time/schedule_time_setting', [
|
||||
'schedule_time' => $schedule_time,
|
||||
'project' => $project,
|
||||
'student' => $student,
|
||||
'student_schedule_id' => $student_schedule_id
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @desc 更改教师排课数据
|
||||
* @param Request $request
|
||||
* @return Response
|
||||
*/
|
||||
public function changeScheduleData(Request $request)
|
||||
{
|
||||
try {
|
||||
$data = $request->post();
|
||||
$teacher_schedule_time = \app\common\model\TeacherScheduleTime::where(['id' => $data['teacher_schedule_time_id']])->findOrEmpty();
|
||||
if ($teacher_schedule_time->isEmpty()) {
|
||||
throw new Exception('未找到教师排课时间');
|
||||
}
|
||||
$changeData = [];
|
||||
if(isset($data['subject_id'])){
|
||||
$teacher_schedule_time->subject_id = $data['subject_id'];
|
||||
}
|
||||
if(isset($data['is_publish'])){
|
||||
$teacher_schedule_time->is_publish = $data['is_publish'];
|
||||
}
|
||||
|
||||
$teacher_schedule_time->save();
|
||||
|
||||
return json([
|
||||
'code' => ResponseCode::WEB_API_SUCCESS,
|
||||
'data' => [],
|
||||
'msg' => 'success'
|
||||
]);
|
||||
} catch (Exception $e) {
|
||||
|
@ -18,18 +18,12 @@
|
||||
|
||||
<!-- 表格顶部工具栏 -->
|
||||
<script type="text/html" id="table-toolbar">
|
||||
<!-- <button class="pear-btn pear-btn-primary pear-btn-md" lay-event="add" permission="app.admin.teacher.insert">-->
|
||||
<!-- <i class="layui-icon layui-icon-add-1"></i>新增-->
|
||||
<!-- </button>-->
|
||||
<!-- <button class="pear-btn pear-btn-danger pear-btn-md" lay-event="batchRemove" permission="app.admin.teacher.delete">-->
|
||||
<!-- <i class="layui-icon layui-icon-delete"></i>删除-->
|
||||
<!-- </button>-->
|
||||
|
||||
</script>
|
||||
|
||||
<!-- 表格行工具栏 -->
|
||||
<script type="text/html" id="table-bar">
|
||||
<button class="pear-btn pear-btn-xs tool-btn" lay-event="check_schedule" permission="app.admin.teacher.update">查看排课</button>
|
||||
<!-- <button class="pear-btn pear-btn-xs tool-btn" lay-event="remove" permission="app.admin.teacher.delete">删除</button>-->
|
||||
<button class="pear-btn pear-btn-xs tool-btn" lay-event="student_schedule" permission="app.admin.teacher.update">查看排课</button>
|
||||
</script>
|
||||
|
||||
<script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
|
||||
@ -130,8 +124,8 @@
|
||||
remove(obj);
|
||||
} else if (obj.event === "edit") {
|
||||
edit(obj);
|
||||
}else if (obj.event === "check_schedule") {
|
||||
check_schedule(obj);
|
||||
}else if (obj.event === "student_schedule") {
|
||||
student_schedule(obj);
|
||||
} else if (obj.event === "rest_password") {
|
||||
rest_password(obj);
|
||||
}
|
||||
@ -213,7 +207,7 @@
|
||||
});
|
||||
}
|
||||
// 老师课程安排
|
||||
let check_schedule = function(obj) {
|
||||
let student_schedule = function(obj) {
|
||||
console.log(21312,obj);
|
||||
let student_id = obj.data['student_id'];
|
||||
let month = obj.data['month'];
|
||||
|
226
plugin/admin/app/view/student/schedule_time_setting.html
Normal file
226
plugin/admin/app/view/student/schedule_time_setting.html
Normal file
@ -0,0 +1,226 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="zh-cn">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>更新页面</title>
|
||||
<link rel="stylesheet" href="/app/admin/component/pear/css/pear.css"/>
|
||||
<link rel="stylesheet" href="/app/admin/component/jsoneditor/css/jsoneditor.css"/>
|
||||
<link rel="stylesheet" href="/app/admin/admin/css/reset.css"/>
|
||||
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<form class="layui-form">
|
||||
|
||||
<div class="mainBox">
|
||||
<div class="main-container mr-5">
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">教师</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="teacher_name" value="{$schedule_time['teacher_name']}" disabled
|
||||
class="layui-input">
|
||||
<input type="hidden" name="teacher_id" value="{$schedule_time['teacher_id']}" class="layui-input">
|
||||
<input type="hidden" name="id" value="{$schedule_time['id']}" class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">月份</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="month" value="{$schedule_time['month']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">日期</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="date" value="{$schedule_time['date']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">时间</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="time" value="{$schedule_time['time']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">课时/小时</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="hour" value="{$schedule_time['hour']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">课程</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="subject_name" value="{$schedule_time['subject_name']}" disabled class="layui-input">
|
||||
<input type="hidden" name="subject_id" value="{$schedule_time['subject_id']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">学生</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="student_name" value="{$schedule_time['student_name']}" disabled class="layui-input">
|
||||
<input type="hidden" name="student_id" value="{$schedule_time['student_id']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">是否发布</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="radio" name="is_publish" value="0" title="未发布" lay-filter="changePublish" {if($schedule_time['is_publish'] ==
|
||||
0)} checked {/if}>
|
||||
<input type="radio" name="is_publish" value="1" title="发布" lay-filter="changePublish" {if($schedule_time['is_publish'] == 1)}
|
||||
checked {/if}>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="bottom">
|
||||
<div class="button-container">
|
||||
<button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
|
||||
提交
|
||||
</button>
|
||||
<button type="reset" class="pear-btn pear-btn-md">
|
||||
重置
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
|
||||
<script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
|
||||
<script src="/app/admin/component/pear/pear.js"></script>
|
||||
<script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
|
||||
<script src="/app/admin/admin/js/permission.js"></script>
|
||||
|
||||
<script>
|
||||
|
||||
// 相关接口
|
||||
const PRIMARY_KEY = "id";
|
||||
const SELECT_API = "/app/admin/teacher-schedule-time/scheduleTime" + location.search;
|
||||
const UPDATE_API = "/app/admin/teacher-schedule-time/update";
|
||||
|
||||
// 获取数据库记录
|
||||
layui.use(["form", "util", "popup"], function () {
|
||||
let $ = layui.$;
|
||||
let form = layui.form;
|
||||
form.render()
|
||||
|
||||
form.on('radio(changePublish)', function (data) {
|
||||
var elem = data.elem; // 获得 select 原始 DOM 对象
|
||||
var value = data.value; // 获得被选中的值
|
||||
var othis = data.othis; // 获得 select 元素被替换后的 jQuery 对象
|
||||
console.log(value)
|
||||
let schedule_time_id = "{$schedule_time['id']}";
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/studentSchedule/changeScheduleData',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: {schedule_time_id: schedule_time_id, 'is_publish': value},
|
||||
success: function (res) {
|
||||
return layui.popup.success("操作成功", function () {
|
||||
parent.refresh();
|
||||
});
|
||||
}
|
||||
});
|
||||
})
|
||||
|
||||
form.on('select(changeSubject)', function (data) {
|
||||
var elem = data.elem; // 获得 select 原始 DOM 对象
|
||||
var value = data.value; // 获得被选中的值
|
||||
var othis = data.othis; // 获得 select 元素被替换后的 jQuery 对象
|
||||
console.log(value)
|
||||
let teacher_schedule_time_id = "{$schedule_time['id']}";
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/teacherScheduleTime/changeScheduleData',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: {teacher_schedule_time_id: teacher_schedule_time_id, 'subject_id': value},
|
||||
success: function (res) {
|
||||
|
||||
return layui.popup.success("操作成功", function () {
|
||||
parent.refresh();
|
||||
});
|
||||
}
|
||||
});
|
||||
})
|
||||
|
||||
form.on('checkbox(check_student)', function (data) {
|
||||
var elem = data.elem; // 获得 checkbox 原始 DOM 对象
|
||||
var othis = data.othis;
|
||||
var type = elem.checked ? 'add' : 'remove'; // 获得 checkbox 选中状态
|
||||
var student_id = elem.value; // 获得 checkbox 值
|
||||
let teacher_schedule_time_id = "{$schedule_time['id']}";
|
||||
var that = this;
|
||||
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/studentSchedule/addStudentSchedule',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: {student_id: student_id, type: type, teacher_schedule_time_id: teacher_schedule_time_id},
|
||||
success: function (res) {
|
||||
|
||||
console.log(111, othis.prop('checked'))
|
||||
if (res.code) {
|
||||
$(that).prop("checked", false)
|
||||
form.render()
|
||||
return layui.popup.failure(res.msg, function () {
|
||||
});
|
||||
}
|
||||
return layui.popup.success("操作成功", function () {
|
||||
// parent.refreshTable();
|
||||
// parent.refreshTable();
|
||||
// parent.location.reload();
|
||||
// parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
//提交事件
|
||||
layui.use(["form", "popup"], function () {
|
||||
|
||||
|
||||
// 字段验证允许为空
|
||||
layui.form.verify({
|
||||
phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
|
||||
email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
|
||||
url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
|
||||
number: [/(^$)|^\d+$/, '只能填写数字'],
|
||||
date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
|
||||
identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
|
||||
});
|
||||
layui.form.on("submit(save)", function (data) {
|
||||
// data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/teacherScheduleTime/scheduleTimeSet',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: data.field,
|
||||
success: function (res) {
|
||||
if (res.code) {
|
||||
return layui.popup.failure(res.msg);
|
||||
}
|
||||
return layui.popup.success("操作成功", function () {
|
||||
// parent.refreshTable();
|
||||
parent.refreshTable();
|
||||
parent.location.reload();
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
});
|
||||
}
|
||||
});
|
||||
return false;
|
||||
});
|
||||
});
|
||||
|
||||
</script>
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
@ -178,9 +178,9 @@
|
||||
},
|
||||
eventClick: function (arg) {
|
||||
console.log('点击时间', arg)
|
||||
console.log('点击时间', arg.event.extendedProps.free_time_id)
|
||||
console.log('点击时间', arg.event.extendedProps.schedule_time_id)
|
||||
|
||||
let free_time_id = arg.event.extendedProps.free_time_id
|
||||
let schedule_time_id = arg.event.extendedProps.schedule_time_id
|
||||
// 表格编辑数据
|
||||
layer.open({
|
||||
type: 2,
|
||||
@ -188,8 +188,8 @@
|
||||
title: "学生排课",
|
||||
shade: 0.1,
|
||||
maxmin: true,
|
||||
area: ["750px", "700px"],
|
||||
content: "/app/admin/teacher/scheduleTimeSet?free_time_id=" + free_time_id
|
||||
area: ["650px", "600px"],
|
||||
content: "/app/admin/studentSchedule/studentScheduleTimeSet?schedule_time_id=" + schedule_time_id
|
||||
});
|
||||
// if (confirm('您确定要删除此事件吗?')) {
|
||||
// arg.event.remove()
|
||||
@ -257,6 +257,14 @@
|
||||
|
||||
calendar.render();
|
||||
// });
|
||||
|
||||
// 刷新表格数据
|
||||
window.refresh = function() {
|
||||
calendar.render();
|
||||
// 重新渲染日历
|
||||
calendar.refetchEvents()
|
||||
parent.refreshTable();
|
||||
}
|
||||
});
|
||||
|
||||
//提交事件
|
||||
|
@ -17,7 +17,8 @@
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">教师</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="teacher_name" value="{$schedule_time['teacher_name']}" disabled class="layui-input">
|
||||
<input type="text" name="teacher_name" value="{$schedule_time['teacher_name']}" disabled
|
||||
class="layui-input">
|
||||
<input type="hidden" name="teacher_id" value="{$schedule_time['teacher_id']}" class="layui-input">
|
||||
<input type="hidden" name="id" value="{$schedule_time['id']}" class="layui-input">
|
||||
</div>
|
||||
@ -52,20 +53,23 @@
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">是否发布</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="radio" name="is_publish" value="0" title="未发布" {if($schedule_time['is_publish'] == 0)} checked {/if}>
|
||||
<input type="radio" name="is_publish" value="1" title="发布" {if($schedule_time['is_publish'] == 1)} checked {/if}>
|
||||
<!-- <input type="checkbox" name="is_publish" title="发布|未发布" lay-skin="switch" value="1" { if($schedule_time['is_publish'] == 1)} checked {/if} >-->
|
||||
<!-- <input type="text" name="hour" value="{$schedule_time['hour']}" disabled class="layui-input">-->
|
||||
<input type="radio" name="is_publish" value="0" title="未发布" lay-filter="changePublish" {if($schedule_time['is_publish'] ==
|
||||
0)} checked {/if}>
|
||||
<input type="radio" name="is_publish" value="1" title="发布" lay-filter="changePublish" {if($schedule_time['is_publish'] == 1)}
|
||||
checked {/if}>
|
||||
<!-- <input type="checkbox" name="is_publish" title="发布|未发布" lay-skin="switch" value="1" { if($schedule_time['is_publish'] == 1)} checked {/if} >-->
|
||||
<!-- <input type="text" name="hour" value="{$schedule_time['hour']}" disabled class="layui-input">-->
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">课程</label>
|
||||
<div class="layui-input-block">
|
||||
<select lay-search name="subject_id" lay-verify="require">
|
||||
<select lay-search name="subject_id" lay-verify="require" lay-filter="changeSubject">
|
||||
<option value="0">请选择</option>
|
||||
{foreach $project as $item}
|
||||
<option value="{$item['id']}" {if $schedule_time['subject_id'] == $item['id'] } selected {/if}>{$item['subject_name']}</option>
|
||||
<option value="{$item['id']}" {if $schedule_time[
|
||||
'subject_id'] == $item['id'] } selected {/if}>{$item['subject_name']}</option>
|
||||
{/foreach}
|
||||
</select>
|
||||
</div>
|
||||
@ -75,7 +79,9 @@
|
||||
<label class="layui-form-label">学生</label>
|
||||
<div class="layui-input-block">
|
||||
{foreach $student as $item}
|
||||
<input type="checkbox" name="student_id[]" title="{$item['student_name']}" lay-skin="tag" lay-filter="check_student" {if in_array($item['id'], $student_schedule_id)} checked {/if} value="{$item['id']}">
|
||||
<input type="checkbox" name="student_id[]" title="{$item['student_name']}" lay-skin="tag"
|
||||
lay-filter="check_student" {if in_array($item['id'], $student_schedule_id)} checked {/if}
|
||||
value="{$item['id']}">
|
||||
{/foreach}
|
||||
</div>
|
||||
</div>
|
||||
@ -113,7 +119,46 @@
|
||||
let form = layui.form;
|
||||
form.render()
|
||||
|
||||
form.on('checkbox(check_student)', function(data){
|
||||
form.on('radio(changePublish)', function (data) {
|
||||
var elem = data.elem; // 获得 select 原始 DOM 对象
|
||||
var value = data.value; // 获得被选中的值
|
||||
var othis = data.othis; // 获得 select 元素被替换后的 jQuery 对象
|
||||
console.log(value)
|
||||
let teacher_schedule_time_id = "{$schedule_time['id']}";
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/teacherScheduleTime/changeScheduleData',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: {teacher_schedule_time_id: teacher_schedule_time_id, 'is_publish': value},
|
||||
success: function (res) {
|
||||
return layui.popup.success("操作成功", function () {
|
||||
parent.refresh();
|
||||
});
|
||||
}
|
||||
});
|
||||
})
|
||||
|
||||
form.on('select(changeSubject)', function (data) {
|
||||
var elem = data.elem; // 获得 select 原始 DOM 对象
|
||||
var value = data.value; // 获得被选中的值
|
||||
var othis = data.othis; // 获得 select 元素被替换后的 jQuery 对象
|
||||
console.log(value)
|
||||
let teacher_schedule_time_id = "{$schedule_time['id']}";
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/teacherScheduleTime/changeScheduleData',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: {teacher_schedule_time_id: teacher_schedule_time_id, 'subject_id': value},
|
||||
success: function (res) {
|
||||
|
||||
return layui.popup.success("操作成功", function () {
|
||||
parent.refresh();
|
||||
});
|
||||
}
|
||||
});
|
||||
})
|
||||
|
||||
form.on('checkbox(check_student)', function (data) {
|
||||
var elem = data.elem; // 获得 checkbox 原始 DOM 对象
|
||||
var othis = data.othis;
|
||||
var type = elem.checked ? 'add' : 'remove'; // 获得 checkbox 选中状态
|
||||
@ -128,7 +173,7 @@
|
||||
data: {student_id: student_id, type: type, teacher_schedule_time_id: teacher_schedule_time_id},
|
||||
success: function (res) {
|
||||
|
||||
console.log(111,othis.prop('checked'))
|
||||
console.log(111, othis.prop('checked'))
|
||||
if (res.code) {
|
||||
$(that).prop("checked", false)
|
||||
form.render()
|
||||
@ -149,6 +194,8 @@
|
||||
|
||||
//提交事件
|
||||
layui.use(["form", "popup"], function () {
|
||||
|
||||
|
||||
// 字段验证允许为空
|
||||
layui.form.verify({
|
||||
phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
|
||||
|
@ -72,7 +72,7 @@
|
||||
<div id='external-events'>
|
||||
<h4>老师信息</h4>
|
||||
<div>
|
||||
<div class='fc-event-main'><?= $teacher['teacher_name']?></div>
|
||||
<div class='fc-event-main'>{$teacher['teacher_name']}</div>
|
||||
</div>
|
||||
<div style="display: flex;flex-direction: column;">
|
||||
<div style="width: 100px;height: 20px;">
|
||||
@ -116,7 +116,7 @@
|
||||
<!-- </p>-->
|
||||
</div>
|
||||
|
||||
<div id='calendar' style="height: 650px;width: 750px;"></div>
|
||||
<div id='schedule_calendar' style="height: 650px;width: 750px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
@ -161,7 +161,7 @@
|
||||
// }
|
||||
// });
|
||||
// document.addEventListener('DOMContentLoaded', function () {
|
||||
var calendarEl = document.getElementById('calendar');
|
||||
var calendarEl = document.getElementById('schedule_calendar');
|
||||
|
||||
var calendar = new FullCalendar.Calendar(calendarEl, {
|
||||
// plugins: [ 'interaction', 'dayGrid', 'timeGrid' ],
|
||||
@ -179,7 +179,7 @@
|
||||
list: '列表'
|
||||
},
|
||||
allDayText : '全天',
|
||||
// initialDate: '2024-07-14',
|
||||
initialDate: '{$init_date}',
|
||||
eventLimit: 4, // 显示更多
|
||||
navLinks: true, // can click day/week names to navigate views
|
||||
selectable: true,
|
||||
@ -199,9 +199,9 @@
|
||||
},
|
||||
eventClick: function (arg) {
|
||||
console.log('点击时间', arg)
|
||||
console.log('点击时间', arg.event.extendedProps.free_time_id)
|
||||
console.log('点击时间', arg.event.extendedProps.schedule_time_id)
|
||||
|
||||
let free_time_id = arg.event.extendedProps.free_time_id
|
||||
let schedule_time_id = arg.event.extendedProps.schedule_time_id
|
||||
// 表格编辑数据
|
||||
layer.open({
|
||||
type: 2,
|
||||
@ -210,7 +210,7 @@
|
||||
shade: 0.1,
|
||||
maxmin: true,
|
||||
area: ["750px", "700px"],
|
||||
content: "/app/admin/teacher/scheduleTimeSet?free_time_id=" + free_time_id
|
||||
content: "/app/admin/teacherScheduleTime/scheduleTimeSet?schedule_time_id=" + schedule_time_id
|
||||
});
|
||||
// if (confirm('您确定要删除此事件吗?')) {
|
||||
// arg.event.remove()
|
||||
@ -219,8 +219,6 @@
|
||||
editable: true,
|
||||
dayMaxEvents: true, // allow "more" link when too many events
|
||||
events: function (info, successCallback, failureCallback) {
|
||||
console.log('12312313', info)
|
||||
|
||||
let start_date = info.startStr;
|
||||
let end_date = info.endStr;
|
||||
let teacher_id = "{$teacher['id']}"
|
||||
@ -230,19 +228,11 @@
|
||||
dateType: "json",
|
||||
data: {id: teacher_id, start_date: start_date, end_date: end_date},
|
||||
success: function (res) {
|
||||
console.log(res)
|
||||
if (res.code == 0) {
|
||||
successCallback(res.data);
|
||||
} else {
|
||||
failureCallback(res.errStr);
|
||||
failureCallback(res.msg);
|
||||
}
|
||||
// if (res.code) {
|
||||
// return layui.popup.failure(res.msg);
|
||||
// }
|
||||
// return layui.popup.success("操作成功", function () {
|
||||
// parent.refreshTable();
|
||||
// parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
// });
|
||||
}
|
||||
});
|
||||
},
|
||||
@ -277,7 +267,14 @@
|
||||
});
|
||||
|
||||
calendar.render();
|
||||
// });
|
||||
|
||||
// 刷新表格数据
|
||||
window.refresh = function() {
|
||||
calendar.render();
|
||||
// 重新渲染日历
|
||||
calendar.refetchEvents()
|
||||
parent.refreshTable();
|
||||
}
|
||||
});
|
||||
|
||||
//提交事件
|
||||
@ -298,10 +295,7 @@
|
||||
});
|
||||
});
|
||||
|
||||
// 刷新表格数据
|
||||
window.refreshTable = function() {
|
||||
parent.refreshTable();
|
||||
}
|
||||
|
||||
</script>
|
||||
|
||||
|
||||
|
@ -1,353 +0,0 @@
|
||||
|
||||
<!DOCTYPE html>
|
||||
<html lang="zh-cn">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>浏览页面</title>
|
||||
<link rel="stylesheet" href="/app/admin/component/pear/css/pear.css" />
|
||||
<link rel="stylesheet" href="/app/admin/admin/css/reset.css" />
|
||||
</head>
|
||||
<body class="pear-container">
|
||||
|
||||
<!-- 数据表格 -->
|
||||
<div class="layui-card">
|
||||
<div class="layui-card-body">
|
||||
<table id="data-table" lay-filter="data-table"></table>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 表格顶部工具栏 -->
|
||||
<script type="text/html" id="table-toolbar">
|
||||
<button class="pear-btn pear-btn-primary pear-btn-md" lay-event="add" permission="app.admin.teacher.insert">
|
||||
<i class="layui-icon layui-icon-add-1"></i>新增
|
||||
</button>
|
||||
<button class="pear-btn pear-btn-danger pear-btn-md" lay-event="batchRemove" permission="app.admin.teacher.delete">
|
||||
<i class="layui-icon layui-icon-delete"></i>删除
|
||||
</button>
|
||||
</script>
|
||||
|
||||
<!-- 表格行工具栏 -->
|
||||
<script type="text/html" id="table-bar">
|
||||
<button class="pear-btn pear-btn-xs tool-btn" lay-event="edit" permission="app.admin.teacher.update">编辑</button>
|
||||
<button class="pear-btn pear-btn-xs tool-btn" lay-event="check_schedule" permission="app.admin.teacher.update">查看排课</button>
|
||||
<button class="pear-btn pear-btn-xs tool-btn" lay-event="rest_password" permission="app.admin.teacher.update">重置密码</button>
|
||||
<button class="pear-btn pear-btn-xs tool-btn" lay-event="remove" permission="app.admin.teacher.delete">删除</button>
|
||||
</script>
|
||||
|
||||
<script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
|
||||
<script src="/app/admin/component/pear/pear.js"></script>
|
||||
<script src="/app/admin/admin/js/permission.js"></script>
|
||||
<script src="/app/admin/admin/js/common.js"></script>
|
||||
|
||||
<script>
|
||||
|
||||
// 相关常量
|
||||
const PRIMARY_KEY = "id";
|
||||
const SELECT_API = "/app/admin/teacherFreeTime/getTeacherScheduleMonth?teacher_id={$teacher['id']}";
|
||||
const UPDATE_API = "/app/admin/teacher/update";
|
||||
const DELETE_API = "/app/admin/teacher/delete";
|
||||
const INSERT_URL = "/app/admin/teacher/insert";
|
||||
const UPDATE_URL = "/app/admin/teacher/update";
|
||||
|
||||
// 表格渲染
|
||||
layui.use(["table", "form", "common", "popup", "util"], function() {
|
||||
let table = layui.table;
|
||||
let form = layui.form;
|
||||
let $ = layui.$;
|
||||
let common = layui.common;
|
||||
let util = layui.util;
|
||||
|
||||
// 表头参数
|
||||
let cols = [
|
||||
{
|
||||
type: "checkbox",
|
||||
align: "center"
|
||||
},{
|
||||
title: "老师",align: "center",
|
||||
field: "teacher_name",
|
||||
},{
|
||||
title: "月份",align: "center",
|
||||
field: "month",
|
||||
},{
|
||||
title: "总时间段/个",align: "center",
|
||||
field: "total_courses",
|
||||
templet: function (d) {
|
||||
let field = "total_courses";
|
||||
return '<span class="layui-badge layui-bg-blue">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "总时长/h",align: "center",
|
||||
field: "total_hours",
|
||||
templet: function (d) {
|
||||
let field = "total_hours";
|
||||
return '<span class="layui-badge layui-bg-blue">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "已安排课程",align: "center",
|
||||
field: "has_subject",
|
||||
templet: function (d) {
|
||||
let field = "has_subject";
|
||||
return '<span class="layui-badge layui-bg-green">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "未安排课程",align: "center",
|
||||
field: "has_no_subject",
|
||||
templet: function (d) {
|
||||
let field = "has_no_subject";
|
||||
return '<span class="layui-badge layui-bg-oragne">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "已安排时长/h",align: "center",
|
||||
field: "total_scheduled_hours",
|
||||
templet: function (d) {
|
||||
let field = "total_scheduled_hours";
|
||||
return '<span class="layui-badge layui-bg-green">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "未安排时长/h",align: "center",
|
||||
field: "total_nonscheduled_hours",
|
||||
templet: function (d) {
|
||||
let field = "total_nonscheduled_hours";
|
||||
return '<span class="layui-badge layui-bg-oragne">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "安排已发布时长/h",align: "center",
|
||||
field: "total_published_scheduled_hours",
|
||||
templet: function (d) {
|
||||
let field = "total_published_scheduled_hours";
|
||||
return '<span class="layui-badge layui-bg-green">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "安排未发布时长/h",align: "center",
|
||||
field: "total_unpublished_scheduled_hours",
|
||||
templet: function (d) {
|
||||
let field = "total_unpublished_scheduled_hours";
|
||||
return '<span class="layui-badge layui-bg-cyan">'+ d[field] +'</span>';
|
||||
}
|
||||
},{
|
||||
title: "deleted_at",align: "center",
|
||||
field: "deleted_at",
|
||||
hide: true,
|
||||
},{
|
||||
title: "操作",
|
||||
toolbar: "#table-bar",
|
||||
align: "center",
|
||||
fixed: "right",
|
||||
width: 180,
|
||||
}
|
||||
];
|
||||
|
||||
// 渲染表格
|
||||
table.render({
|
||||
elem: "#data-table",
|
||||
url: SELECT_API,
|
||||
page: true,
|
||||
cols: [cols],
|
||||
skin: "line",
|
||||
size: "lg",
|
||||
toolbar: "#table-toolbar",
|
||||
autoSort: false,
|
||||
defaultToolbar: [{
|
||||
title: "刷新",
|
||||
layEvent: "refresh",
|
||||
icon: "layui-icon-refresh",
|
||||
}, "filter", "print", "exports"],
|
||||
done: function () {
|
||||
layer.photos({photos: 'div[lay-id="data-table"]', anim: 5});
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
// 编辑或删除行事件
|
||||
table.on("tool(data-table)", function(obj) {
|
||||
if (obj.event === "remove") {
|
||||
remove(obj);
|
||||
} else if (obj.event === "edit") {
|
||||
edit(obj);
|
||||
}else if (obj.event === "check_schedule") {
|
||||
check_schedule(obj);
|
||||
} else if (obj.event === "rest_password") {
|
||||
rest_password(obj);
|
||||
}
|
||||
});
|
||||
|
||||
// 表格顶部工具栏事件
|
||||
table.on("toolbar(data-table)", function(obj) {
|
||||
if (obj.event === "add") {
|
||||
add();
|
||||
} else if (obj.event === "refresh") {
|
||||
refreshTable();
|
||||
} else if (obj.event === "batchRemove") {
|
||||
batchRemove(obj);
|
||||
}
|
||||
});
|
||||
|
||||
// 表格顶部搜索事件
|
||||
form.on("submit(table-query)", function(data) {
|
||||
table.reload("data-table", {
|
||||
page: {
|
||||
curr: 1
|
||||
},
|
||||
where: data.field
|
||||
})
|
||||
return false;
|
||||
});
|
||||
|
||||
// 表格顶部搜索重置事件
|
||||
form.on("submit(table-reset)", function(data) {
|
||||
table.reload("data-table", {
|
||||
where: []
|
||||
})
|
||||
});
|
||||
|
||||
// 字段允许为空
|
||||
form.verify({
|
||||
phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
|
||||
email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
|
||||
url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
|
||||
number: [/(^$)|^\d+$/,'只能填写数字'],
|
||||
date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
|
||||
identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
|
||||
});
|
||||
|
||||
// 表格排序事件
|
||||
table.on("sort(data-table)", function(obj){
|
||||
table.reload("data-table", {
|
||||
initSort: obj,
|
||||
scrollPos: "fixed",
|
||||
where: {
|
||||
field: obj.field,
|
||||
order: obj.type
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
// 表格新增数据
|
||||
let add = function() {
|
||||
layer.open({
|
||||
type: 2,
|
||||
title: "新增",
|
||||
shade: 0.1,
|
||||
maxmin: true,
|
||||
area: [common.isModile()?"100%":"500px", common.isModile()?"100%":"450px"],
|
||||
content: INSERT_URL
|
||||
});
|
||||
}
|
||||
|
||||
// 表格编辑数据
|
||||
let edit = function(obj) {
|
||||
let value = obj.data[PRIMARY_KEY];
|
||||
layer.open({
|
||||
type: 2,
|
||||
title: "修改",
|
||||
shade: 0.1,
|
||||
maxmin: true,
|
||||
area: [common.isModile()?"100%":"500px", common.isModile()?"100%":"450px"],
|
||||
content: UPDATE_URL + "?" + PRIMARY_KEY + "=" + value
|
||||
});
|
||||
}
|
||||
// 老师课程安排
|
||||
let check_schedule = function(obj) {
|
||||
console.log(21312,obj);
|
||||
let teacher_id = obj.data['teacher_id'];
|
||||
let month = obj.data['month'];
|
||||
let index = layer.open({
|
||||
type: 2,
|
||||
title: "修改",
|
||||
shade: 0.1,
|
||||
maxmin: true,
|
||||
area: [common.isModile()?"100%":"500px", common.isModile()?"100%":"450px"],
|
||||
content: '/app/admin/teacher/teacherScheduleTime?teacher_id=' + teacher_id + '&month=' + month
|
||||
});
|
||||
layer.full(index);
|
||||
}
|
||||
// 表格编辑数据
|
||||
let rest_password = function(obj) {
|
||||
console.log()
|
||||
let data = {};
|
||||
data[PRIMARY_KEY] = obj.data[PRIMARY_KEY];
|
||||
let new_password = 'YD' + obj.data['account'] + '123';
|
||||
layer.confirm("确定充值密码?重置后新密码为【"+ new_password +"】", {
|
||||
icon: 3,
|
||||
title: "提示"
|
||||
}, function(index) {
|
||||
layer.close(index);
|
||||
let loading = layer.load();
|
||||
$.ajax({
|
||||
url: '/app/admin/teacher/resetPassword',
|
||||
data: data,
|
||||
dataType: "json",
|
||||
type: "post",
|
||||
success: function(res) {
|
||||
layer.close(loading);
|
||||
if (res.code) {
|
||||
return layui.popup.failure(res.msg);
|
||||
}
|
||||
return layui.popup.success("操作成功", refreshTable);
|
||||
}
|
||||
})
|
||||
});
|
||||
}
|
||||
|
||||
// 删除一行
|
||||
let remove = function(obj) {
|
||||
return doRemove(obj.data[PRIMARY_KEY]);
|
||||
}
|
||||
|
||||
// 删除多行
|
||||
let batchRemove = function(obj) {
|
||||
let checkIds = common.checkField(obj, PRIMARY_KEY);
|
||||
if (checkIds === "") {
|
||||
layui.popup.warning("未选中数据");
|
||||
return false;
|
||||
}
|
||||
doRemove(checkIds.split(","));
|
||||
}
|
||||
|
||||
// 执行删除
|
||||
let doRemove = function (ids) {
|
||||
let data = {};
|
||||
data[PRIMARY_KEY] = ids;
|
||||
layer.confirm("确定删除?", {
|
||||
icon: 3,
|
||||
title: "提示"
|
||||
}, function(index) {
|
||||
layer.close(index);
|
||||
let loading = layer.load();
|
||||
$.ajax({
|
||||
url: DELETE_API,
|
||||
data: data,
|
||||
dataType: "json",
|
||||
type: "post",
|
||||
success: function(res) {
|
||||
layer.close(loading);
|
||||
if (res.code) {
|
||||
return layui.popup.failure(res.msg);
|
||||
}
|
||||
return layui.popup.success("操作成功", refreshTable);
|
||||
}
|
||||
})
|
||||
});
|
||||
}
|
||||
|
||||
// 刷新表格数据
|
||||
window.refreshTable = function() {
|
||||
table.reloadData("data-table", {
|
||||
scrollPos: "fixed",
|
||||
done: function (res, curr) {
|
||||
if (curr > 1 && res.data && !res.data.length) {
|
||||
curr = curr - 1;
|
||||
table.reloadData("data-table", {
|
||||
page: {
|
||||
curr: curr
|
||||
},
|
||||
})
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
})
|
||||
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
@ -79,13 +79,13 @@
|
||||
<span class="layui-badge-dot layui-bg-danger"></span>
|
||||
<span>未排课</span>
|
||||
</div>
|
||||
<div style="width: 120px;height: 20px;">
|
||||
<span class="layui-badge-dot layui-bg-orange"></span>
|
||||
<span>已排课,未发布</span>
|
||||
</div>
|
||||
<!-- <div style="width: 120px;height: 20px;">-->
|
||||
<!-- <span class="layui-badge-dot layui-bg-orange"></span>-->
|
||||
<!-- <span>已排课,未发布</span>-->
|
||||
<!-- </div>-->
|
||||
<div style="width: 100px;height: 20px;">
|
||||
<span class="layui-badge-dot layui-bg-green"></span>
|
||||
<span>已发布</span>
|
||||
<span>已排课</span>
|
||||
</div>
|
||||
</div>
|
||||
<div id='external-events-list'>
|
||||
|
@ -17,49 +17,50 @@
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">教师</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="teacher_name" value="{$schedule_time['teacher_name']}" disabled class="layui-input">
|
||||
<input type="hidden" name="teacher_id" value="{$schedule_time['teacher_id']}" class="layui-input">
|
||||
<input type="hidden" name="id" value="{$schedule_time['id']}" class="layui-input">
|
||||
<input type="text" name="teacher_name" value="{$free_time['teacher_name']}" disabled class="layui-input">
|
||||
<input type="hidden" name="teacher_id" value="{$free_time['teacher_id']}" class="layui-input">
|
||||
<input type="hidden" name="id" value="{$free_time['id']}" class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">月份</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="month" value="{$schedule_time['month']}" disabled class="layui-input">
|
||||
<input type="text" name="month" value="{$free_time['month']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">日期</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="date" value="{$schedule_time['date']}" disabled class="layui-input">
|
||||
<input type="text" name="date" value="{$free_time['date']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">时间</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="time" value="{$schedule_time['time']}" disabled class="layui-input">
|
||||
<input type="text" name="time" value="{$free_time['time']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">课时/小时</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="text" name="hour" value="{$schedule_time['hour']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
<div class="layui-form-item">
|
||||
<label class="layui-form-label">是否发布</label>
|
||||
<div class="layui-input-block">
|
||||
<input type="radio" disabled name="is_publish" value="0" title="未发布" {if($schedule_time['is_publish'] == 0)} checked {/if}>
|
||||
<input type="radio" disabled name="is_publish" value="1" title="发布" {if($schedule_time['is_publish'] == 1)} checked {/if}>
|
||||
<input type="text" name="hour" value="{$free_time['hour']}" disabled class="layui-input">
|
||||
</div>
|
||||
</div>
|
||||
<!-- <div class="layui-form-item">-->
|
||||
<!-- <label class="layui-form-label">是否发布</label>-->
|
||||
<!-- <div class="layui-input-block">-->
|
||||
<!-- <input type="radio" disabled name="is_publish" value="0" title="未发布" {if($free_time['is_publish'] == 0)} checked {/if}>-->
|
||||
<!-- <input type="radio" disabled name="is_publish" value="1" title="发布" {if($free_time['is_publish'] == 1)} checked {/if}>-->
|
||||
<!-- </div>-->
|
||||
<!-- </div>-->
|
||||
|
||||
<fieldset class="layui-elem-field">
|
||||
<legend>排课时间</legend>
|
||||
<div class="layui-field-box" id="schedule_free_time">
|
||||
{if (empty($teacher_schedule_time))}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-input-inline" style="width: 250px;">
|
||||
<input type="text" name="schedule_time[]" lay-verify="required" placeholder="请选择排课时间" curNum='1' autocomplete="off" class="layui-input time">
|
||||
@ -69,6 +70,20 @@
|
||||
<button type="button" class="layui-btn layui-btn-xs layui-bg-red remove-schedule-time" lay-event="remove" permission="app.admin.teacher.delete">删除</button>
|
||||
</div>
|
||||
</div>
|
||||
{else /}
|
||||
{foreach $teacher_schedule_time as $index=>$item}
|
||||
<div class="layui-form-item">
|
||||
<div class="layui-input-inline" style="width: 250px;">
|
||||
<input type="text" name="schedule_time[$index+1]" lay-verify="required" value="{$item['time']}" placeholder="请选择排课时间" curNum='{$index+1}' autocomplete="off" class="layui-input time">
|
||||
</div>
|
||||
<div class="layui-input-inline" style="margin-left: 50px;padding-top: 10px;">
|
||||
<button type="button" class="layui-btn layui-btn-xs layui-bg-green add-schedule-time" lay-event="remove" permission="app.admin.teacher.delete">添加</button>
|
||||
<button type="button" class="layui-btn layui-btn-xs layui-bg-red remove-schedule-time" lay-event="remove" permission="app.admin.teacher.delete">删除</button>
|
||||
</div>
|
||||
</div>
|
||||
{/foreach}
|
||||
|
||||
{/if}
|
||||
</div>
|
||||
</fieldset>
|
||||
|
||||
@ -101,19 +116,6 @@
|
||||
const UPDATE_API = "/app/admin/teacher-schedule-time/update";
|
||||
|
||||
|
||||
// 字段 时间 time
|
||||
layui.use(["laydate"], function() {
|
||||
let laydate = layui.laydate;
|
||||
layui.laydate.render({
|
||||
elem: ".time",
|
||||
type: "time",
|
||||
format: 'HH:mm',
|
||||
btns:['clear','confirm'],
|
||||
min: '09:30:00',
|
||||
max: '17:30:00',
|
||||
// range: '-',
|
||||
});
|
||||
})
|
||||
|
||||
|
||||
// 获取数据库记录
|
||||
@ -129,9 +131,14 @@
|
||||
type: "time",
|
||||
format: 'HH:mm',
|
||||
btns:['clear','confirm'],
|
||||
min: '09:30:00',
|
||||
max: '17:30:00',
|
||||
range: ' - ',
|
||||
min: "{$limit_time['start_time']}:00",
|
||||
max: "{$limit_time['end_time']}:59",
|
||||
range: '-',
|
||||
ready: function(date){
|
||||
var layKey = layui.$(this.elem).attr('lay-key');
|
||||
layui.$('#layui-laydate' + layKey).children().eq(0).find('.layui-laydate-list>li').width('50%').last('li').hide();
|
||||
layui.$('#layui-laydate' + layKey).children().eq(1).find('.layui-laydate-list>li').width('50%').last('li').hide();
|
||||
}
|
||||
});
|
||||
|
||||
// 添加时间
|
||||
@ -160,9 +167,14 @@
|
||||
type: "time",
|
||||
format: 'HH:mm',
|
||||
btns:['clear','confirm'],
|
||||
min: "{$limit_time['start_time']}",
|
||||
max: "{$limit_time['end_time']}",
|
||||
range: ' - ',
|
||||
min: "{$limit_time['start_time']}:00",
|
||||
max: "{$limit_time['end_time']}:59",
|
||||
range: '-',
|
||||
ready: function(date){
|
||||
var layKey = layui.$(this.elem).attr('lay-key');
|
||||
layui.$('#layui-laydate' + layKey).children().eq(0).find('.layui-laydate-list>li').width('50%').last('li').hide();
|
||||
layui.$('#layui-laydate' + layKey).children().eq(1).find('.layui-laydate-list>li').width('50%').last('li').hide();
|
||||
}
|
||||
});
|
||||
})
|
||||
|
||||
@ -174,37 +186,37 @@
|
||||
}
|
||||
})
|
||||
|
||||
form.on('checkbox(check_student)', function(data){
|
||||
var elem = data.elem; // 获得 checkbox 原始 DOM 对象
|
||||
var othis = data.othis;
|
||||
var type = elem.checked ? 'add' : 'remove'; // 获得 checkbox 选中状态
|
||||
var student_id = elem.value; // 获得 checkbox 值
|
||||
let teacher_schedule_time_id = "{$schedule_time['id']}";
|
||||
var that = this;
|
||||
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/teacherScheduleTime/addTeacherScheduleTime',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: {student_id: student_id, type: type, teacher_schedule_time_id: teacher_schedule_time_id},
|
||||
success: function (res) {
|
||||
|
||||
console.log(111,othis.prop('checked'))
|
||||
if (res.code) {
|
||||
$(that).prop("checked", false)
|
||||
form.render()
|
||||
return layui.popup.failure(res.msg, function () {
|
||||
});
|
||||
}
|
||||
return layui.popup.success("操作成功", function () {
|
||||
// parent.refreshTable();
|
||||
// parent.refreshTable();
|
||||
// parent.location.reload();
|
||||
// parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
// form.on('checkbox(check_student)', function(data){
|
||||
// var elem = data.elem; // 获得 checkbox 原始 DOM 对象
|
||||
// var othis = data.othis;
|
||||
// var type = elem.checked ? 'add' : 'remove'; // 获得 checkbox 选中状态
|
||||
// var student_id = elem.value; // 获得 checkbox 值
|
||||
// let teacher_schedule_time_id = "{$free_time['id']}";
|
||||
// var that = this;
|
||||
//
|
||||
// layui.$.ajax({
|
||||
// url: '/app/admin/teacherScheduleTime/addTeacherScheduleTime',
|
||||
// type: "POST",
|
||||
// dateType: "json",
|
||||
// data: {student_id: student_id, type: type, teacher_schedule_time_id: teacher_schedule_time_id},
|
||||
// success: function (res) {
|
||||
//
|
||||
// console.log(111,othis.prop('checked'))
|
||||
// if (res.code) {
|
||||
// $(that).prop("checked", false)
|
||||
// form.render()
|
||||
// return layui.popup.failure(res.msg, function () {
|
||||
// });
|
||||
// }
|
||||
// return layui.popup.success("操作成功", function () {
|
||||
// // parent.refreshTable();
|
||||
// // parent.refreshTable();
|
||||
// // parent.location.reload();
|
||||
// // parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
// });
|
||||
// }
|
||||
// });
|
||||
// });
|
||||
});
|
||||
|
||||
|
||||
|
@ -1,289 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="zh-cn">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>更新页面</title>
|
||||
<link rel="stylesheet" href="/app/admin/component/pear/css/pear.css"/>
|
||||
<link rel="stylesheet" href="/app/admin/component/jsoneditor/css/jsoneditor.css"/>
|
||||
<link rel="stylesheet" href="/app/admin/admin/css/reset.css"/>
|
||||
<script src='/app/admin/resource/fullcalendar/index.global6.1.15.min.js'></script>
|
||||
<!-- <script src='https://cdn.jsdelivr.net/npm/fullcalendar@6.1.15/index.global.min.js'></script>-->
|
||||
|
||||
|
||||
<style>
|
||||
|
||||
body {
|
||||
margin-top: 40px;
|
||||
font-size: 14px;
|
||||
font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
|
||||
}
|
||||
|
||||
#external-events {
|
||||
/*position: fixed;*/
|
||||
left: 20px;
|
||||
top: 20px;
|
||||
width: 150px;
|
||||
padding: 0 10px;
|
||||
border: 1px solid #ccc;
|
||||
background: #eee;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
#external-events h4 {
|
||||
font-size: 16px;
|
||||
margin-top: 0;
|
||||
padding-top: 1em;
|
||||
}
|
||||
|
||||
#external-events .fc-event {
|
||||
margin: 3px 0;
|
||||
cursor: move;
|
||||
}
|
||||
|
||||
#external-events p {
|
||||
margin: 1.5em 0;
|
||||
font-size: 11px;
|
||||
color: #666;
|
||||
}
|
||||
|
||||
#external-events p input {
|
||||
margin: 0;
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
#calendar-wrap {
|
||||
margin-left: 200px;
|
||||
}
|
||||
|
||||
#calendar {
|
||||
max-width: 1100px;
|
||||
margin: 0 auto;
|
||||
}
|
||||
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<form class="layui-form">
|
||||
|
||||
<div class="mainBox">
|
||||
<div class="main-container mr-5">
|
||||
<div id='wrap' style="display: flex;">
|
||||
<div id='external-events'>
|
||||
<h4>老师信息</h4>
|
||||
<div>
|
||||
<div class='fc-event-main'>{$teacher['teacher_name']}</div>
|
||||
</div>
|
||||
<div style="display: flex;flex-direction: column;">
|
||||
<div style="width: 100px;height: 20px;">
|
||||
<span class="layui-badge-dot layui-bg-danger"></span>
|
||||
<span>未排课</span>
|
||||
</div>
|
||||
<div style="width: 120px;height: 20px;">
|
||||
<span class="layui-badge-dot layui-bg-orange"></span>
|
||||
<span>已排课,未发布</span>
|
||||
</div>
|
||||
<div style="width: 100px;height: 20px;">
|
||||
<span class="layui-badge-dot layui-bg-green"></span>
|
||||
<span>已发布</span>
|
||||
</div>
|
||||
</div>
|
||||
<div id='external-events-list'>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<div id='calendar' style="height: 650px;width: 750px;"></div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="bottom">
|
||||
<div class="button-container">
|
||||
<button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
|
||||
提交
|
||||
</button>
|
||||
<button type="reset" class="pear-btn pear-btn-md">
|
||||
重置
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
|
||||
<script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
|
||||
<script src="/app/admin/component/pear/pear.js"></script>
|
||||
<script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
|
||||
<script src="/app/admin/admin/js/permission.js"></script>
|
||||
|
||||
<script>
|
||||
|
||||
// 相关接口
|
||||
const PRIMARY_KEY = "id";
|
||||
const SELECT_API = "/app/admin/teacher-free-time/select" + location.search;
|
||||
const UPDATE_API = "/app/admin/teacher-free-time/update";
|
||||
|
||||
|
||||
// // 获取数据库记录
|
||||
layui.use(["form", "util", "popup"], function () {
|
||||
let $ = layui.$;
|
||||
|
||||
// var containerEl = document.getElementById('external-events-list');
|
||||
// new FullCalendar.Draggable(containerEl, {
|
||||
// itemSelector: '.fc-event',
|
||||
// eventData: function (eventEl) {
|
||||
// return {
|
||||
// title: eventEl.innerText.trim()
|
||||
// }
|
||||
// }
|
||||
// });
|
||||
// document.addEventListener('DOMContentLoaded', function () {
|
||||
var calendarEl = document.getElementById('calendar');
|
||||
|
||||
var calendar = new FullCalendar.Calendar(calendarEl, {
|
||||
// plugins: [ 'interaction', 'dayGrid', 'timeGrid' ],
|
||||
locale: 'zh-cn', // 设置中文
|
||||
headerToolbar: {
|
||||
// left: 'prev,next today',
|
||||
left: 'today',
|
||||
center: 'title',
|
||||
right: 'dayGridMonth,timeGridWeek,timeGridDay'
|
||||
},
|
||||
buttonText: {
|
||||
today: '今日',
|
||||
month: '月',
|
||||
week: '周',
|
||||
day: '日',
|
||||
list: '列表'
|
||||
},
|
||||
initialDate: '{$month}',
|
||||
eventLimit: 4, // 显示更多
|
||||
navLinks: true, // can click day/week names to navigate views
|
||||
selectable: true,
|
||||
selectMirror: true,
|
||||
displayEventEnd: true, // 显示结束时间
|
||||
select: function (arg) {
|
||||
// var title = prompt('Event Title:');
|
||||
// if (title) {
|
||||
// calendar.addEvent({
|
||||
// title: title,
|
||||
// start: arg.start,
|
||||
// end: arg.end,
|
||||
// allDay: arg.allDay
|
||||
// })
|
||||
// }
|
||||
// calendar.unselect()
|
||||
},
|
||||
eventClick: function (arg) {
|
||||
console.log('点击时间', arg)
|
||||
console.log('点击时间', arg.event.extendedProps.free_time_id)
|
||||
|
||||
let free_time_id = arg.event.extendedProps.free_time_id
|
||||
// 表格编辑数据
|
||||
layer.open({
|
||||
type: 2,
|
||||
fix: false,
|
||||
title: "学生排课",
|
||||
shade: 0.1,
|
||||
maxmin: true,
|
||||
area: ["750px", "700px"],
|
||||
content: "/app/admin/teacher/scheduleTimeSet?free_time_id=" + free_time_id
|
||||
});
|
||||
// if (confirm('您确定要删除此事件吗?')) {
|
||||
// arg.event.remove()
|
||||
// }
|
||||
},
|
||||
editable: true,
|
||||
allDayText : '全天',
|
||||
dayMaxEvents: true, // allow "more" link when too many events
|
||||
events: function (info, successCallback, failureCallback) {
|
||||
console.log('12312313', info)
|
||||
|
||||
let start_date = info.startStr;
|
||||
let end_date = info.endStr;
|
||||
let teacher_id = "{$teacher['id']}"
|
||||
layui.$.ajax({
|
||||
url: '/app/admin/teacherScheduleTime/getScheduleTime',
|
||||
type: "POST",
|
||||
dateType: "json",
|
||||
data: {id: teacher_id, start_date: start_date, end_date: end_date},
|
||||
success: function (res) {
|
||||
console.log(res)
|
||||
if (res.code == 0) {
|
||||
successCallback(res.data);
|
||||
} else {
|
||||
failureCallback(res.errStr);
|
||||
}
|
||||
// if (res.code) {
|
||||
// return layui.popup.failure(res.msg);
|
||||
// }
|
||||
// return layui.popup.success("操作成功", function () {
|
||||
// parent.refreshTable();
|
||||
// parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
// });
|
||||
}
|
||||
});
|
||||
},
|
||||
eventTextColor: function (obj) {
|
||||
console.log('字体颜色', obj)
|
||||
},
|
||||
eventMouseEnter: function (info) {
|
||||
console.log('鼠标', info)
|
||||
let jsEvent = info.jsEvent
|
||||
|
||||
let tip_content = info.event.title;
|
||||
layer.tips(tip_content, jsEvent.toElement, {
|
||||
tips: 2
|
||||
});
|
||||
|
||||
// 将弹窗添加到页面上
|
||||
// layui.$('body').append(popup);
|
||||
// new toolTop();
|
||||
// layer.open()
|
||||
// var index = layer.open({
|
||||
// type: 4, // page 层类型,其他类型详见「基础属性」
|
||||
// // content: layui.$('.' + jsEvent.toElement.getAttribute('class'))
|
||||
// content: jsEvent.toElement,
|
||||
// tips:2,
|
||||
// });
|
||||
},
|
||||
eventMouseLeave: function (info) {
|
||||
// console.log('移走', info)
|
||||
// layui.$('.popup').remove();
|
||||
layer.closeAll('tips');
|
||||
}
|
||||
});
|
||||
|
||||
calendar.render();
|
||||
// });
|
||||
});
|
||||
|
||||
//提交事件
|
||||
layui.use(["form", "popup"], function () {
|
||||
// 字段验证允许为空
|
||||
layui.form.verify({
|
||||
phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
|
||||
email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
|
||||
url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
|
||||
number: [/(^$)|^\d+$/, '只能填写数字'],
|
||||
date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
|
||||
identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
|
||||
});
|
||||
layui.form.on("submit(save)", function (data) {
|
||||
parent.refreshTable();
|
||||
parent.layer.close(parent.layer.getFrameIndex(window.name));
|
||||
// return false;
|
||||
});
|
||||
});
|
||||
|
||||
// 刷新表格数据
|
||||
window.refreshTable = function() {
|
||||
parent.refreshTable();
|
||||
}
|
||||
</script>
|
||||
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
BIN
public/files/files/202407/2024072117283999381.jpg
Normal file
BIN
public/files/files/202407/2024072117283999381.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 210 KiB |
Loading…
x
Reference in New Issue
Block a user