183 lines
6.2 KiB
PHP
183 lines
6.2 KiB
PHP
<?php
|
|
|
|
namespace app\admin\controller\ContactUs;
|
|
|
|
use app\BaseController;
|
|
use app\common\model\ContactUs\Signup as ModelSignup;
|
|
use app\Request;
|
|
use think\Validate;
|
|
use think\exception\ValidateException;
|
|
use think\facade\Filesystem;
|
|
use app\common\arw\adjfut\src\Excel;
|
|
use app\common\arw\adjfut\src\UploadFile;
|
|
use app\common\exception\Tool;
|
|
use think\facade\Db;
|
|
use think\facade\Env;
|
|
|
|
|
|
class Signup extends BaseController
|
|
{
|
|
/**
|
|
* 获取在线报名列表接口
|
|
*
|
|
* @param Request request
|
|
* @return array
|
|
* @date 2023-04-20
|
|
* @author xjh
|
|
* @since 1.0.0
|
|
*/
|
|
public function getSignupList(): array
|
|
{
|
|
$con = Tool::getOptionalQuery(
|
|
['signup.signup_user_name', 'LIKE'],
|
|
['signup.signup_user_phone', 'LIKE'],
|
|
['signup.signup_user_parents_phone', 'LIKE'],
|
|
['signup.signup_user_home_address', 'LIKE'],
|
|
['signup.signup_user_original_school', 'LIKE'],
|
|
['signup.signup_user_arrival_time', 'LIKE'],
|
|
['signup.signup_user_grad_type', '='],
|
|
['signup.signup_status', '='],
|
|
['signup.classes_guid', '='],
|
|
['signup.signup_create_time', 'BETWEEN', 'data_time'],
|
|
);
|
|
$query = ModelSignup::where($con)
|
|
->field([
|
|
'signup.signup_id',
|
|
'signup.signup_guid',
|
|
'signup.signup_user_name',
|
|
'signup.signup_user_phone',
|
|
'signup.signup_user_parents_phone',
|
|
'signup.signup_user_home_address',
|
|
'signup.signup_user_original_school',
|
|
'signup.signup_user_arrival_time',
|
|
'signup.classes_guid',
|
|
'signup.signup_user_grad_type',
|
|
'signup.signup_status',
|
|
'classes.classes_name',
|
|
'signup.signup_create_time',
|
|
])
|
|
->leftJoin('classes', 'classes.classes_guid = signup.classes_guid')
|
|
->order('signup_create_time', 'desc');
|
|
|
|
return msg("获取在线报名列表成功!", $query);
|
|
}
|
|
|
|
/**
|
|
* 在线报名受理接口
|
|
*
|
|
* @param Request request
|
|
* @return array
|
|
* @date 2023-04-20
|
|
* @author xjh
|
|
* @since 1.0.0
|
|
*/
|
|
public function handleSignupStatus(Request $request): array
|
|
{
|
|
$params = $request->param();
|
|
$this->validate($params, [
|
|
'signup_guid|在线报名guid' => 'require',
|
|
]);
|
|
$msg_data = [];
|
|
$signup_guids = explode(',', $params['signup_guid']);
|
|
$signup_guids_count = count($signup_guids);
|
|
foreach ($signup_guids as $line => $signup_guid) {
|
|
$prefix_text = ($signup_guids_count != 1) ? "第" . ($line + 1) . "行-> " : null;
|
|
try {
|
|
$signup = ModelSignup::where('signup_guid', $signup_guid)->find();
|
|
if (!$signup) throwErrorMsg('该在线报名数据不存在!');
|
|
if ($signup->signup_status == 1) throwErrorMsg('该在线报名数据已处理!');
|
|
$signup->signup_status = 1;
|
|
$signup->save();
|
|
$msg_data[] = $prefix_text . "用户名称【{$signup->signup_user_name}】: <span style='color:#27af49'>受理成功!</span>";
|
|
} catch (\Throwable $th) {
|
|
$msg_data[] = $prefix_text . "用户名称:【{$signup->signup_user_name}】: <span style='color:red'>{$th->getMessage()}</span>";
|
|
}
|
|
};
|
|
return msg(0, implode('<br>', $msg_data));
|
|
}
|
|
|
|
|
|
// /**
|
|
// * 添加在线报名
|
|
// */
|
|
// public function addSignup(Request $request): array
|
|
// {
|
|
// $params = $request->param();
|
|
// $this->validate($params, [
|
|
// 'signup_user_name|报名用户名称' => 'require',
|
|
// 'signup_user_phone|报名用户电话' => 'require',
|
|
// 'signup_user_parents_phone|报名用户家长电话' => 'require',
|
|
// 'signup_user_home_address|报名用户家庭地址' => 'require',
|
|
// 'signup_user_original_school|报名用户原就读学校' => 'require',
|
|
// 'signup_user_arrival_time|报名用户预计到校时间' => 'require',
|
|
// 'classes_guid|报名用户选择班级guid(外键)' => 'require',
|
|
// 'signup_user_grad_type|报名用户毕业类型(字典)' => 'require',
|
|
// 'signup_status|报名受理状态(字典)' => 'require'
|
|
// ]);
|
|
// $model = ModelSignup::create($params, [
|
|
// 'signup_guid',
|
|
// 'signup_create_user_guid',
|
|
// 'signup_update_user_guid',
|
|
// 'signup_user_name',
|
|
// 'signup_user_phone',
|
|
// 'signup_user_parents_phone',
|
|
// 'signup_user_home_address',
|
|
// 'signup_user_original_school',
|
|
// 'signup_user_arrival_time',
|
|
// 'classes_guid',
|
|
// 'signup_user_grad_type',
|
|
// 'signup_status'
|
|
// ]);
|
|
// return msg('添加成功!');
|
|
// }
|
|
|
|
/**
|
|
* 删除在线报名接口
|
|
*
|
|
* @param Request request
|
|
* @return array
|
|
* @date 2023-04-20
|
|
* @author xjh
|
|
* @since 1.0.0
|
|
*/
|
|
public function deleteSignup(Request $request): array
|
|
{
|
|
$params = $request->param();
|
|
$this->validate($params, [
|
|
'signup_guid|在线报名guid' => 'require',
|
|
]);
|
|
$signup = ModelSignup::where([
|
|
'signup_guid' => explode(',', $params['signup_guid'])
|
|
])->select();
|
|
$signup->delete();
|
|
return msg('删除成功!');
|
|
}
|
|
|
|
/**
|
|
* 导出Excel接口
|
|
*
|
|
* @param Request request
|
|
* @return array
|
|
* @date 2023-04-20
|
|
* @author xjh
|
|
* @since 1.0.0
|
|
*/
|
|
public function exportExcel(Request $request): void
|
|
{
|
|
$params = $request->param();
|
|
$con = [
|
|
['classes.classes_delete_time', 'NULL', null],
|
|
];
|
|
if (isset($params['signup_guids']) && $params['signup_guids']) {
|
|
$con['signup.signup_guid'] = explode(',', $params['signup_guids']);
|
|
}
|
|
$select = ModelSignup::where($con)
|
|
->leftJoin('classes', 'classes.classes_guid = signup.classes_guid')
|
|
->order('signup_create_time', 'desc')
|
|
->select()
|
|
->toArray();
|
|
|
|
ModelSignup::exportExcel($select);
|
|
}
|
|
}
|