houde_web_api/app/admin/controller/ContactUs/Signup.php

131 lines
3.8 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
{
return msg(ModelSignup::handleStatus($request));
}
/**
* 删除在线报名接口
*
* @param Request request
* @return array
* @date 2023-04-20
* @author xjh
* @since 1.0.0
*/
public function deleteSignup(Request $request): array
{
Db::startTrans();
try {
$params = $request->param();
$this->validate($params, ['signup_guid|在线报名guid' => 'require',]);
$signup = ModelSignup::where(['signup_guid' => explode(',', $params['signup_guid'])])->select();
$signup->delete();
Db::commit();
return msg('删除成功!');
} catch (\Throwable $th) {
Db::rollback();
throw $th;
}
}
/**
* 导出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);
}
}