学生排课,添加家长

This commit is contained in:
Dai 2024-07-16 23:51:41 +08:00
parent 939c2c9930
commit b503c1de16
6 changed files with 256 additions and 188 deletions

View File

@ -23,6 +23,9 @@ use support\Model;
*/
class Student extends BaseModel
{
public function parent()
{
return $this->hasOne(StudentParent::class, 'id', 'parent_id')->bind(['parent_name']);
}
}

View File

@ -74,6 +74,11 @@ class TeacherScheduleTimeService
}
}
/**
* @desc 获取排课列表
* @param $request
* @return array
*/
public function getScheduleTime($request)
{
try {
@ -87,8 +92,17 @@ class TeacherScheduleTimeService
}
$data = $request->get();
$schedule = TeacherScheduleTime::where(['teacher_id'=>$teacher->id, 'date'=>$data['schedule_date']])->select();
$schedule = TeacherScheduleTime::where(['teacher_id'=>$teacher->id, 'month'=>$data['month']])
->field('id,teacher_id,date,time,hour,month,subject_id,is_publish')
->with(['subject'])
->select();
// foreach ($schedule as &$item){
// if(!$item->is_publish){
// $item->subject_name = '';
// $item->english_name = '';
// }
// }
return [
'code' => ResponseCode::SUCCESS,

View File

@ -2,6 +2,7 @@
namespace plugin\admin\app\controller;
use app\common\model\StudentParent;
use app\constant\ResponseCode;
use support\Request;
use support\Response;
@ -39,6 +40,39 @@ class StudentController extends Crud
return view('student/index');
}
public function select(Request $request): Response
{
try {
$data = $request->get();
$student = \app\common\model\Student::order('id asc');
if (isset($data['id']) && $data['id']) {
$student->where(['id' => $data['id']]);
}
$limit = (int)$request->get('limit', 10);
$limit = $limit <= 0 ? 10 : $limit;
$page = (int)$request->get('page');
$page = $page > 0 ? $page : 1;
$total = $student->count();
$list = $student->page($page, $limit)->with(['parent'])->select();
return json([
'code' => ResponseCode::WEB_API_SUCCESS,
'count' => $total,
'data' => $list,
'msg' => 'success'
]);
} catch (Exception $e) {
return json([
'code' => ResponseCode::WEB_API_FAIL,
'msg' => $e->getMessage()
]);
}
}
/**
* 插入
* @param Request $request
@ -64,7 +98,7 @@ class StudentController extends Crud
'password' => $password,
'salt' => $salt,
'avatar' => $request_data['avatar'],
'parent_id' => 0,
'parent_id' => $request_data['parent_id'],
]);
return json([
@ -73,7 +107,9 @@ class StudentController extends Crud
]);
// return parent::insert($request);
}
return view('student/insert');
$parent = StudentParent::order('id asc')->field('id,parent_name,account')->select()->toArray();
return view('student/insert', ['parent' => $parent]);
}
/**
@ -98,7 +134,7 @@ class StudentController extends Crud
'student_name' => $request_data['student_name'],
'account' => $request_data['account'],
'avatar' => $request_data['avatar'],
'parent_id' => 0,
'parent_id' => $request_data['parent_id'],
];
} else {
$salt = random_str(16);
@ -109,7 +145,7 @@ class StudentController extends Crud
'password' => $password,
'salt' => $salt,
'avatar' => $request_data['avatar'],
'parent_id' => 0,
'parent_id' => $request_data['parent_id'],
];
}
@ -128,7 +164,9 @@ class StudentController extends Crud
// return parent::update($request);
}
return view('student/update');
$parent = StudentParent::order('id asc')->field('id,parent_name,account')->select()->toArray();
return view('student/update', ['parent' => $parent]);
}
@ -150,7 +188,7 @@ class StudentController extends Crud
'salt' => $salt,
'password' => $password
]);
if(!$res){
if (!$res) {
throw new Exception('重置失败');
}

View File

@ -102,7 +102,7 @@
hide: true
}, {
title: "家长", align: "center",
field: "parent_id",
field: "parent_name",
}, {
title: "创建时间", align: "center",
field: "created_at",
@ -213,7 +213,7 @@
title: "新增",
shade: 0.1,
maxmin: true,
area: [common.isModile() ? "100%" : "500px", common.isModile() ? "100%" : "450px"],
area: [common.isModile() ? "100%" : "750px", common.isModile() ? "100%" : "700px"],
content: INSERT_URL
});
}
@ -226,7 +226,7 @@
title: "修改",
shade: 0.1,
maxmin: true,
area: [common.isModile() ? "100%" : "500px", common.isModile() ? "100%" : "450px"],
area: [common.isModile() ? "100%" : "650px", common.isModile() ? "100%" : "700px"],
content: UPDATE_URL + "?" + PRIMARY_KEY + "=" + value
});
}

View File

@ -66,7 +66,12 @@
<div class="layui-form-item">
<label class="layui-form-label">家长</label>
<div class="layui-input-block">
<input type="text" name="parent_id" value="0" class="layui-input">
<select lay-search="" name="parent_id">
<option value="">请选择或搜索家长</option>
{foreach $parent as $item}
<option value="{$item['id']}">{$item['parent_name']}</option>
{/foreach}
</select>
</div>
</div>

View File

@ -1,201 +1,209 @@
<!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>
<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"/>
<form class="layui-form">
</head>
<body>
<div class="mainBox">
<div class="main-container mr-5">
<div class="layui-form-item">
<label class="layui-form-label required">学生姓名</label>
<div class="layui-input-block">
<input type="text" name="student_name" value="" required lay-verify="required" class="layui-input">
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label required">账号</label>
<div class="layui-input-block">
<input type="text" name="account" value="" required lay-verify="required" 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="password" value="" 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="salt" value="" 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="nickname" value="" class="layui-input">-->
<!-- </div>-->
<!-- </div>-->
<div class="layui-form-item">
<label class="layui-form-label">头像</label>
<div class="layui-input-block">
<img class="img-3" src=""/>
<input type="text" style="display:none" name="avatar" value="" />
<button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="avatar" permission="app.admin.upload.image">
<i class="layui-icon layui-icon-upload"></i>上传图片
</button>
<button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="attachment-choose-avatar" permission="app.admin.upload.attachment">
<i class="layui-icon layui-icon-align-left"></i>选择图片
</button>
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label">家长</label>
<div class="layui-input-block">
<input type="text" name="parent_id" value="" class="layui-input">
</div>
</div>
<form class="layui-form">
<div class="mainBox">
<div class="main-container mr-5">
<div class="layui-form-item">
<label class="layui-form-label required">学生姓名</label>
<div class="layui-input-block">
<input type="text" name="student_name" value="" required lay-verify="required" class="layui-input">
</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">
提交
<div class="layui-form-item">
<label class="layui-form-label required">账号</label>
<div class="layui-input-block">
<input type="text" name="account" value="" required lay-verify="required" 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="password" value="" 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="salt" value="" 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="nickname" value="" class="layui-input">-->
<!-- </div>-->
<!-- </div>-->
<div class="layui-form-item">
<label class="layui-form-label">头像</label>
<div class="layui-input-block">
<img class="img-3" src=""/>
<input type="text" style="display:none" name="avatar" value=""/>
<button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="avatar"
permission="app.admin.upload.image">
<i class="layui-icon layui-icon-upload"></i>上传图片
</button>
<button type="reset" class="pear-btn pear-btn-md">
重置
<button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="attachment-choose-avatar"
permission="app.admin.upload.attachment">
<i class="layui-icon layui-icon-align-left"></i>选择图片
</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>
<div class="layui-form-item">
<label class="layui-form-label">家长</label>
<div class="layui-input-block">
<!-- <input type="text" name="parent_id" value="" class="layui-input">-->
<select lay-search="" name="parent_id">
<option value="">请选择或搜索家长</option>
{foreach $parent as $item}
<option value="{$item['id']}">{$item['parent_name']}</option>
{/foreach}
</select>
</div>
</div>
// 相关接口
const PRIMARY_KEY = "id";
const SELECT_API = "/app/admin/student/select" + location.search;
const UPDATE_API = "/app/admin/student/update";
</div>
</div>
// 获取数据库记录
layui.use(["form", "util", "popup"], function () {
let $ = layui.$;
$.ajax({
url: SELECT_API,
dataType: "json",
success: function (res) {
// 给表单初始化数据
layui.each(res.data[0], function (key, value) {
let obj = $('*[name="'+key+'"]');
if (key === "password") {
obj.attr("placeholder", "不更新密码请留空");
return;
}
if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
if (obj[0].nodeName.toLowerCase() === "textarea") {
obj.val(value);
} else {
obj.attr("value", value);
obj[0].value = value;
}
});
// 字段 头像 avatar
layui.use(["upload", "layer"], function() {
let input = layui.$("#avatar").prev();
input.prev().attr("src", input.val());
layui.$("#attachment-choose-avatar").on("click", function() {
parent.layer.open({
type: 2,
title: "选择附件",
content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
area: ["95%", "90%"],
success: function (layero, index) {
parent.layui.$("#layui-layer" + index).data("callback", function (data) {
input.val(data.url).prev().attr("src", data.url);
});
}
});
});
layui.upload.render({
elem: "#avatar",
acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
url: "/app/admin/upload/image",
field: "__file__",
done: function (res) {
if (res.code > 0) return layui.layer.msg(res.msg);
this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
}
});
});
// ajax返回失败
if (res.code) {
layui.popup.failure(res.msg);
}
<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/student/select" + location.search;
const UPDATE_API = "/app/admin/student/update";
// 获取数据库记录
layui.use(["form", "util", "popup"], function () {
let $ = layui.$;
$.ajax({
url: SELECT_API,
dataType: "json",
success: function (res) {
// 给表单初始化数据
layui.each(res.data[0], function (key, value) {
let obj = $('*[name="' + key + '"]');
if (key === "password") {
obj.attr("placeholder", "不更新密码请留空");
return;
}
if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
if (obj[0].nodeName.toLowerCase() === "textarea") {
obj.val(value);
} else {
obj.attr("value", value);
obj[0].value = value;
}
});
});
//提交事件
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: UPDATE_API,
type: "POST",
dateType: "json",
data: data.field,
success: function (res) {
if (res.code) {
return layui.popup.failure(res.msg);
// 字段 头像 avatar
layui.use(["upload", "layer"], function () {
let input = layui.$("#avatar").prev();
input.prev().attr("src", input.val());
layui.$("#attachment-choose-avatar").on("click", function () {
parent.layer.open({
type: 2,
title: "选择附件",
content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
area: ["95%", "90%"],
success: function (layero, index) {
parent.layui.$("#layui-layer" + index).data("callback", function (data) {
input.val(data.url).prev().attr("src", data.url);
});
}
return layui.popup.success("操作成功", function () {
parent.refreshTable();
parent.layer.close(parent.layer.getFrameIndex(window.name));
});
});
});
layui.upload.render({
elem: "#avatar",
acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
url: "/app/admin/upload/image",
field: "__file__",
done: function (res) {
if (res.code > 0) return layui.layer.msg(res.msg);
this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
}
});
return false;
});
// ajax返回失败
if (res.code) {
layui.popup.failure(res.msg);
}
}
});
});
//提交事件
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: UPDATE_API,
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.layer.close(parent.layer.getFrameIndex(window.name));
});
}
});
return false;
});
});
</script>
</script>
</body>
</body>
</html>