houde_web_api/app/admin/controller/ContactUs/Signup.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);
}
}