|  |  |  | @ -0,0 +1,232 @@ | 
			
		
	
		
			
				
					|  |  |  |  | <?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="需要输出的关联关系数组,包括:teacher,courseSettings,coursePeriods"), | 
			
		
	
		
			
				
					|  |  |  |  |      *     @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="排序类型"), | 
			
		
	
		
			
				
					|  |  |  |  |      *     @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"), | 
			
		
	
		
			
				
					|  |  |  |  |      *     @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"), | 
			
		
	
		
			
				
					|  |  |  |  |      *     @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(); | 
			
		
	
		
			
				
					|  |  |  |  |         // 签到用户 | 
			
		
	
		
			
				
					|  |  |  |  |         $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(); | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |         $list = CourseSign::with(['course.typeDetail', 'user'])->whereHas('user', function ($query) use ($all) { | 
			
		
	
		
			
				
					|  |  |  |  |             if (isset($all['name'])) { | 
			
		
	
		
			
				
					|  |  |  |  |                 $query->where('name', 'like', '%' . $all['name'] . '%'); | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |             if (isset($all['mobile'])) { | 
			
		
	
		
			
				
					|  |  |  |  |                 $query->where('mobile', 'like', '%' . $all['mobile'] . '%'); | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |         })->where(function ($query) use ($all, $courseContentCheck) { | 
			
		
	
		
			
				
					|  |  |  |  |             if (isset($all['course_id'])) { | 
			
		
	
		
			
				
					|  |  |  |  |                 $query->where('course_id', $all['course_id']); | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |             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')); | 
			
		
	
		
			
				
					|  |  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |             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)) { | 
			
		
	
		
			
				
					|  |  |  |  |                             continue; | 
			
		
	
		
			
				
					|  |  |  |  |                         } | 
			
		
	
		
			
				
					|  |  |  |  |                         $query->whereBetween($key, [$from, $to]); | 
			
		
	
		
			
				
					|  |  |  |  |                     } | 
			
		
	
		
			
				
					|  |  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |         })->orderBy($all['sort_name'] ?? 'id', $all['sort_type'] ?? 'desc') | 
			
		
	
		
			
				
					|  |  |  |  |             ->orderBy('created_at', 'desc'); | 
			
		
	
		
			
				
					|  |  |  |  |         if (isset($all['is_export']) && !empty($all['is_export'])) { | 
			
		
	
		
			
				
					|  |  |  |  |             $list = $list->limit(5000)->get()->toArray(); | 
			
		
	
		
			
				
					|  |  |  |  |             foreach ($list as &$item) { | 
			
		
	
		
			
				
					|  |  |  |  |                 $courseContentCheck = CourseContentCheck::where('user_id', $item['user_id']) | 
			
		
	
		
			
				
					|  |  |  |  |                     ->where(function ($query) use ($all) { | 
			
		
	
		
			
				
					|  |  |  |  |                         if (isset($all['course_content_id'])) { | 
			
		
	
		
			
				
					|  |  |  |  |                             $query->where('course_content_id', $all['course_content_id']); | 
			
		
	
		
			
				
					|  |  |  |  |                         } | 
			
		
	
		
			
				
					|  |  |  |  |                         if (isset($all['course_id'])) { | 
			
		
	
		
			
				
					|  |  |  |  |                             $query->where('course_id', $all['course_id']); | 
			
		
	
		
			
				
					|  |  |  |  |                         } | 
			
		
	
		
			
				
					|  |  |  |  |                     })->first(); | 
			
		
	
		
			
				
					|  |  |  |  |                 // 是否存在courseContentCheck | 
			
		
	
		
			
				
					|  |  |  |  |                 $item['course_content_check_created_at'] = ''; | 
			
		
	
		
			
				
					|  |  |  |  |                 if ($courseContentCheck) { | 
			
		
	
		
			
				
					|  |  |  |  |                     $item['course_content_check_text'] = '已签到'; | 
			
		
	
		
			
				
					|  |  |  |  |                     $item['course_content_check_created_at'] = $courseContentCheck->created_at; | 
			
		
	
		
			
				
					|  |  |  |  |                 } else { | 
			
		
	
		
			
				
					|  |  |  |  |                     $item['course_content_check_text'] = '未签到'; | 
			
		
	
		
			
				
					|  |  |  |  |                 } | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |             return Excel::download(new CommonExport($list, $all['export_fields'] ?? ''), $all['file_name'] ?? '' . date('YmdHis') . '.xlsx'); | 
			
		
	
		
			
				
					|  |  |  |  |         } else { | 
			
		
	
		
			
				
					|  |  |  |  |             // 输出 | 
			
		
	
		
			
				
					|  |  |  |  |             $list = $list->paginate($all['page_size'] ?? 20); | 
			
		
	
		
			
				
					|  |  |  |  |             foreach ($list as $item) { | 
			
		
	
		
			
				
					|  |  |  |  |                 $item->course_content_check = CourseContentCheck::where('user_id', $item->user_id) | 
			
		
	
		
			
				
					|  |  |  |  |                     ->where(function ($query) use ($all) { | 
			
		
	
		
			
				
					|  |  |  |  |                         if (isset($all['course_content_id'])) { | 
			
		
	
		
			
				
					|  |  |  |  |                             $query->where('course_content_id', $all['course_content_id']); | 
			
		
	
		
			
				
					|  |  |  |  |                         } | 
			
		
	
		
			
				
					|  |  |  |  |                         if (isset($all['course_id'])) { | 
			
		
	
		
			
				
					|  |  |  |  |                             $query->where('course_id', $all['course_id']); | 
			
		
	
		
			
				
					|  |  |  |  |                         } | 
			
		
	
		
			
				
					|  |  |  |  |                     })->first(); | 
			
		
	
		
			
				
					|  |  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |         return $this->success(['list' => $list, 'course_content_check_count' => $courseContentCheck->count()]); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  |     /** | 
			
		
	
		
			
				
					|  |  |  |  |      * @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="暂无" | 
			
		
	
		
			
				
					|  |  |  |  |      *     ) | 
			
		
	
		
			
				
					|  |  |  |  |      * ) | 
			
		
	
		
			
				
					|  |  |  |  |      */ | 
			
		
	
		
			
				
					|  |  |  |  |     public | 
			
		
	
		
			
				
					|  |  |  |  |     function show() | 
			
		
	
		
			
				
					|  |  |  |  |     { | 
			
		
	
		
			
				
					|  |  |  |  |         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="操作成功" | 
			
		
	
		
			
				
					|  |  |  |  |      *     ) | 
			
		
	
		
			
				
					|  |  |  |  |      * ) | 
			
		
	
		
			
				
					|  |  |  |  |      */ | 
			
		
	
		
			
				
					|  |  |  |  |     public | 
			
		
	
		
			
				
					|  |  |  |  |     function save() | 
			
		
	
		
			
				
					|  |  |  |  |     { | 
			
		
	
		
			
				
					|  |  |  |  |         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="暂无" | 
			
		
	
		
			
				
					|  |  |  |  |      *     ) | 
			
		
	
		
			
				
					|  |  |  |  |      * ) | 
			
		
	
		
			
				
					|  |  |  |  |      */ | 
			
		
	
		
			
				
					|  |  |  |  |     public | 
			
		
	
		
			
				
					|  |  |  |  |     function destroy() | 
			
		
	
		
			
				
					|  |  |  |  |     { | 
			
		
	
		
			
				
					|  |  |  |  |         return parent::destroy(); | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | } |