You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

232 lines
9.7 KiB

3 months ago
<?php
namespace App\Http\Controllers\Admin;
use App\Exports\BaseExport;
use App\Exports\CommonExport;
use App\Helpers\ResponseCode;
use App\Models\AppointmentType;
use App\Models\Book;
use App\Models\Calendar;
use App\Models\Company;
use App\Models\Course;
use App\Models\CourseContentCheck;
use App\Models\CourseContentEvaluationAsk;
use App\Models\CourseContentEvaluationForm;
use App\Models\CourseSign;
use App\Models\CustomForm;
use App\Models\CustomFormField;
use App\Models\EmailTemplate;
use App\Models\SupplyDemand;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Validator;
use Maatwebsite\Excel\Facades\Excel;
use Rap2hpoutre\FastExcel\FastExcel;
class CourseContentCheckController extends BaseController
{
/**
* 构造函数
*/
public function __construct()
{
parent::__construct(new CourseContentCheck());
}
/**
* @OA\Get(
* path="/api/admin/course-content-check/index",
* tags={"签到管理"},
* summary="列表",
* description="",
* @OA\Parameter(name="is_export", in="query", @OA\Schema(type="string"), required=false, description="是否导出0否1是"),
* @OA\Parameter(name="export_fields", in="query", @OA\Schema(type="string"), required=false, description="需要导出的字段数组"),
* @OA\Parameter(name="filter", in="query", @OA\Schema(type="string"), required=false, description="查询条件。数组"),
* @OA\Parameter(name="show_relation", in="query", @OA\Schema(type="string"), required=false, description="需要输出的关联关系数组包括teachercourseSettingscoursePeriods"),
* @OA\Parameter(name="page_size", in="query", @OA\Schema(type="string"), required=false, description="每页显示的条数"),
* @OA\Parameter(name="page", in="query", @OA\Schema(type="string"), required=false, description="页码"),
* @OA\Parameter(name="sort_name", in="query", @OA\Schema(type="string"), required=false, description="排序字段名字"),
* @OA\Parameter(name="sort_type", in="query", @OA\Schema(type="string"), required=false, description="排序类型"),
3 months ago
* @OA\Parameter(name="course_id", in="query", @OA\Schema(type="string"), required=false, description="course_id"),
* @OA\Parameter(name="course_content_id", in="query", @OA\Schema(type="string"), required=false, description="course_content_id"),
3 months ago
* @OA\Parameter(name="has_check", in="query", @OA\Schema(type="string"), required=false, description="是否签到0否1是"),
* @OA\Parameter(name="name", in="query", @OA\Schema(type="string"), required=false, description="name"),
* @OA\Parameter(name="mobile", in="query", @OA\Schema(type="string"), required=false, description="mobile"),
3 months ago
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Response(
* response="200",
* description="暂无"
* )
* )
*/
public function index()
{
$all = request()->all();
3 months ago
// 签到用户
$courseContentCheck = CourseContentCheck::where(function ($query) use ($all) {
if (isset($all['course_id'])) {
$query->where('course_id', $all['course_id']);
}
if (isset($all['course_content_id'])) {
$query->where('course_content_id', $all['course_content_id']);
}
})->get();
3 months ago
$list = CourseSign::with(['course.typeDetail', 'user'])->whereHas('user', function ($query) use ($all) {
3 months ago
if (isset($all['name'])) {
$query->where('name', 'like', '%' . $all['name'] . '%');
}
if (isset($all['mobile'])) {
$query->where('mobile', 'like', '%' . $all['mobile'] . '%');
}
3 months ago
})->where(function ($query) use ($all, $courseContentCheck) {
3 months ago
if (isset($all['course_id'])) {
$query->where('course_id', $all['course_id']);
}
3 months ago
if (isset($all['has_check'])) {
if ($all['has_check'] == 1) {
$query->whereIn('user_id', $courseContentCheck->pluck('user_id'));
} else {
$query->whereNotIn('user_id', $courseContentCheck->pluck('user_id'));
}
}
3 months ago
if (isset($all['filter']) && !empty($all['filter'])) {
foreach ($all['filter'] as $condition) {
$key = $condition['key'] ?? null;
$op = $condition['op'] ?? null;
$value = $condition['value'] ?? null;
if (!isset($key) || !isset($op) || !isset($value)) {
continue;
}
// 等于
if ($op == 'eq') {
$query->where($key, $value);
}
// 不等于
if ($op == 'neq') {
$query->where($key, '!=', $value);
}
// 模糊搜索
if ($op == 'like') {
$query->where($key, 'like', '%' . $value . '%');
}
// 否定模糊搜索
if ($op == 'notlike') {
$query->where($key, 'not like', '%' . $value . '%');
}
// 范围搜索
if ($op == 'range') {
list($from, $to) = explode(',', $value);
if (empty($from) || empty($to)) {
3 months ago
continue;
}
3 months ago
$query->whereBetween($key, [$from, $to]);
3 months ago
}
}
3 months ago
}
})->orderBy($all['sort_name'] ?? 'id', $all['sort_type'] ?? 'desc')
3 months ago
->orderBy('created_at', 'desc');
if (isset($all['is_export']) && !empty($all['is_export'])) {
$list = $list->limit(5000)->get()->toArray();
3 months ago
foreach ($list as &$item) {
3 months ago
$courseContentCheck = CourseContentCheck::where('user_id', $item['user_id'])
3 months ago
->where(function ($query) use ($all) {
if (isset($all['course_content_id'])) {
$query->where('course_content_id', $all['course_content_id']);
}
3 months ago
if (isset($all['course_id'])) {
$query->where('course_id', $all['course_id']);
}
3 months ago
})->first();
3 months ago
// 是否存在courseContentCheck
3 months ago
$item['course_content_check'] = $courseContentCheck;
3 months ago
if ($courseContentCheck) {
3 months ago
$item['course_content_check_text'] = '已签到';
3 months ago
} else {
3 months ago
$item['course_content_check_text'] = '未签到';
3 months ago
}
}
3 months ago
return Excel::download(new CommonExport($list, $all['export_fields'] ?? ''), $all['file_name'] ?? '' . date('YmdHis') . '.xlsx');
} else {
// 输出
$list = $list->paginate($all['page_size'] ?? 20);
3 months ago
foreach ($list as $item) {
3 months ago
$item->course_content_check = CourseContentCheck::where('user_id', $item->user_id)
3 months ago
->where(function ($query) use ($all) {
if (isset($all['course_content_id'])) {
$query->where('course_content_id', $all['course_content_id']);
}
3 months ago
if (isset($all['course_id'])) {
$query->where('course_id', $all['course_id']);
}
3 months ago
})->first();
}
3 months ago
}
return $this->success($list);
}
/**
* @OA\Get(
* path="/api/admin/course-content-check/show",
* tags={"签到管理"},
* summary="详情",
* description="",
* @OA\Parameter(name="id", in="query", @OA\Schema(type="string"), required=true, description="id"),
* @OA\Parameter(name="show_relation", in="query", @OA\Schema(type="string"), required=false, description="需要输出的关联关系数组,填写输出指定数据"),
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Response(
* response="200",
* description="暂无"
* )
* )
*/
3 months ago
public
3 months ago
function show()
{
3 months ago
return parent::show();
}
/**
* @OA\Post(
* path="/api/admin/course-content-check/save",
* tags={"签到管理"},
* summary="保存",
* description="",
* @OA\Parameter(name="id", in="query", @OA\Schema(type="int"), required=true, description="Id(存在更新,不存在新增)"),
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="认证token"),
* @OA\Response(
* response="200",
* description="操作成功"
* )
* )
*/
3 months ago
public
3 months ago
function save()
{
3 months ago
return parent::save();
}
/**
* @OA\Get(
* path="/api/admin/course-content-check/destroy",
* tags={"签到管理"},
* summary="删除",
* description="",
* @OA\Parameter(name="id", in="query", @OA\Schema(type="string"), required=true, description="id"),
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Response(
* response="200",
* description="暂无"
* )
* )
*/
3 months ago
public
3 months ago
function destroy()
{
3 months ago
return parent::destroy();
}
}