OrganizationsController.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411
  1. <?php
  2. namespace App\Http\Controllers\Admin\Course;
  3. use App\Contracts\Repositories\User\UserRepository;
  4. use App\Http\Controllers\Controller;
  5. use App\Repositories\Enums\ModelStatusEnum;
  6. use App\Repositories\Enums\ResponseCodeEnum;
  7. use App\Repositories\Models\Course\Course;
  8. use App\Repositories\Models\Course\Organization;
  9. use App\Repositories\Models\Course\OrganizationCourse;
  10. use App\Repositories\Models\Course\OrganizationStudent;
  11. use App\Repositories\Models\Course\UserRecord;
  12. use App\Repositories\Models\User\User;
  13. use App\Repositories\Models\UserVideoWatchRecord;
  14. use Illuminate\Http\Request;
  15. use Illuminate\Support\Str;
  16. use Jiannei\Response\Laravel\Support\Facades\Response;
  17. use Prettus\Validator\Contracts\ValidatorInterface;
  18. use App\Contracts\Repositories\Course\OrganizationRepository;
  19. use App\Repositories\Validators\Course\OrganizationValidator;
  20. /**
  21. * Class OrganizationsController.
  22. *
  23. * @package namespace App\Http\Controllers\Course;
  24. */
  25. class OrganizationsController extends Controller
  26. {
  27. /**
  28. * @var OrganizationRepository
  29. */
  30. protected $repository;
  31. /**
  32. * @var OrganizationValidator
  33. */
  34. protected $validator;
  35. /**
  36. * OrganizationsController constructor.
  37. *
  38. * @param OrganizationRepository $repository
  39. * @param OrganizationValidator $validator
  40. */
  41. public function __construct(OrganizationRepository $repository, OrganizationValidator $validator)
  42. {
  43. $this->repository = $repository;
  44. $this->validator = $validator;
  45. }
  46. /**
  47. * 班级列表
  48. * @param Request $request
  49. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  50. * Author: Mead
  51. */
  52. public function index(Request $request)
  53. {
  54. $lists = $this->repository->paginate($request->get('per_page', self::PAGE_NUM));
  55. return Response::success($lists);
  56. }
  57. /**
  58. * 创建
  59. * @param Request $request
  60. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource|void
  61. * @throws \Illuminate\Validation\ValidationException
  62. * Author: Mead
  63. */
  64. public function store(Request $request)
  65. {
  66. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_CREATE));
  67. try {
  68. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_CREATE)));
  69. $data['user_id'] = login_user_id();
  70. if (!$data['coordinator_id']) {
  71. $data['coordinator_id'] = login_user_id();
  72. }
  73. $data['slug'] = Str::random();
  74. $model = $this->repository->create($data);
  75. return Response::success($model);
  76. } catch (\Exception $e) {
  77. return $this->errorStore($e);
  78. }
  79. }
  80. /**
  81. * 编辑
  82. * @param Request $request
  83. * @param $id
  84. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  85. * @throws \Illuminate\Validation\ValidationException
  86. * Author: Mead
  87. */
  88. public function update(Request $request, $id)
  89. {
  90. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_UPDATE));
  91. // if (!Organization::query()->where('coordinator_id', login_user_id())->where('id', $id)->exists()) {
  92. //
  93. // return $this->error('您暂无编辑权限!');
  94. // }
  95. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_UPDATE)));
  96. if (isset($data['is_issue']) && $data['is_issue']) {
  97. $this->validate($request, [
  98. 'coordinator_id' => 'required|integer',
  99. 'cover' => 'required|integer',
  100. ], [], ['coordinator_id' => '班主任', 'cover' => '封面图']);
  101. }
  102. try {
  103. $model = $this->repository->update($data, $id);
  104. return Response::success($model);
  105. } catch (\Exception $e) {
  106. $this->errorStore($e);
  107. }
  108. }
  109. /**
  110. * 删除
  111. * @param $id
  112. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  113. * Author: Mead
  114. */
  115. public function destroy($id)
  116. {
  117. // if (!Organization::query()->where('coordinator_id', login_user_id())->where('id', $id)->exists()) {
  118. // return $this->error('您暂无删除权限!');
  119. // }
  120. try {
  121. $this->repository->delete($id);
  122. return Response::success(null, T('successfully delete.'));
  123. } catch (\Exception $exception) {
  124. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  125. }
  126. }
  127. /**
  128. * 详情
  129. * @param $slug
  130. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  131. * Author: Mead
  132. */
  133. public function show($slug)
  134. {
  135. $model = $this->repository->where('slug', $slug)->first();
  136. if (!$model) {
  137. return $this->error('找不到资源');
  138. }
  139. $model = $this->repository->parserResult($model);
  140. return Response::success($model);
  141. }
  142. /**
  143. * 关联课程
  144. * @param Request $request
  145. * Author: Mead
  146. */
  147. public function syncCourses(Request $request)
  148. {
  149. $this->validate($request, [
  150. 'id' => 'required|integer',
  151. 'course_ids' => 'required|array',
  152. ], [], ['id' => '班级', 'course_ids' => '课程']);
  153. $model = Organization::query()->where('id', $request->get('id'))->where('status', ModelStatusEnum::OK)->first();
  154. if (!$model) {
  155. return $this->error('找不到资源');
  156. }
  157. $course_ids = $request->get('course_ids');
  158. $model->courses()->sync($course_ids);
  159. $model->course_nums = count($course_ids);
  160. $model->save();
  161. return Response::success(null);
  162. }
  163. /**
  164. * 学员列表
  165. * @param Request $request
  166. * @param UserRepository $repository
  167. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  168. * @throws \Illuminate\Validation\ValidationException
  169. * Author: Mead
  170. */
  171. public function students(Request $request, UserRepository $repository)
  172. {
  173. $this->validate($request, [
  174. 'organization_id' => 'required|integer',
  175. ], [], ['id' => '班级']);
  176. $lists = $repository->paginate($request->get('per_page', self::PAGE_NUM));
  177. return Response::success($lists);
  178. }
  179. /**
  180. * 添加学生
  181. * @param Request $request
  182. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  183. * @throws \Illuminate\Validation\ValidationException
  184. * Author: Mead
  185. */
  186. public function storeStudent(Request $request)
  187. {
  188. $this->validate($request, [
  189. 'organization_id' => 'required|integer',
  190. // 'keyword' => 'required|string',
  191. 'user_ids' => 'required|array',
  192. ], [], ['id' => '班级', 'keyword' => '账号\手机号', 'user_ids' => '用户ids']);
  193. // $keyword = $request->get('keyword');
  194. // $users = User::query()->where('status', ModelStatusEnum::OK)->where(function ($query) use ($keyword) {
  195. // return $query->where('username', 'like', "%{$keyword}%")->orWhere('mobile', 'like', "%{$keyword}%");
  196. // })->select(['id', 'username', 'name', 'turename', 'sex', 'mobile'])->get();
  197. //
  198. // if (!$users) {
  199. // return $this->error('找不到该用户');
  200. // }
  201. //
  202. // if (count($users) > 1) {
  203. // return Response::success($users);
  204. // }
  205. // $user_id = $users[0]['id'];
  206. $user_ids = $request->get('user_ids');
  207. $id = $request->get('organization_id');
  208. $model = Organization::query()->where('id', $id)->where('status', ModelStatusEnum::OK)->first();
  209. if (!$model) {
  210. return $this->error('找不到资源');
  211. }
  212. foreach ($user_ids as $user_id) {
  213. $is_student = User::query()->where('id', $user_id)->where('role_id', 0)->status()->exists();
  214. $is_band = OrganizationStudent::query()->where('organization_id', $id)->where('user_id', $user_id)->where('status', ModelStatusEnum::OK)->exists();
  215. if (!$is_band && $is_student) {
  216. OrganizationStudent::query()->create(
  217. [
  218. 'organization_id' => $id,
  219. 'user_id' => $user_id,
  220. ]
  221. );
  222. }
  223. }
  224. $model->student_nums = OrganizationStudent::query()->where('organization_id', $id)->status()->count();
  225. $model->save();
  226. return Response::success(null);
  227. }
  228. /**
  229. * 更新学生信息
  230. * @param Request $request
  231. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  232. * Author: Mead
  233. */
  234. public function updateStudent(Request $request)
  235. {
  236. $this->validate($request, [
  237. 'organization_id' => 'required|integer',
  238. 'user_id' => 'required|integer',
  239. 'type' => 'required|integer',
  240. ], [], ['id' => '班级', 'user_id' => '学员id', 'type' => '身份类型']);
  241. $organization_id = $request->get('organization_id');
  242. $user_id = $request->get('user_id');
  243. $type = $request->get('type');
  244. $model = OrganizationStudent::query()->where('organization_id', $organization_id)->where('user_id', $user_id)->where('status', ModelStatusEnum::OK)->first();
  245. if (!$model) {
  246. return $this->error('找不到该资源');
  247. }
  248. $model->type = $type;
  249. $model->save();
  250. return Response::success(null);
  251. }
  252. /**
  253. * 删除学员
  254. * @param Request $request
  255. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  256. * Author: Mead
  257. */
  258. public function destroyStudents(Request $request)
  259. {
  260. $this->validate($request, [
  261. 'organization_id' => 'required|integer',
  262. 'user_ids' => 'required|array',
  263. ], [], ['organization_id' => '班级', 'ids' => '记录id']);
  264. $organization_id = $request->get('organization_id');
  265. $ids = $request->get('user_ids');
  266. $re = OrganizationStudent::query()->where('organization_id', $organization_id)->whereIn('user_id', $ids)->delete();
  267. if (!$re) {
  268. return $this->error('删除失败');
  269. }
  270. Organization::query()->where('id', $organization_id)->update(['student_nums' => OrganizationStudent::query()->where('organization_id', $organization_id)->status()->count()]);
  271. return Response::success(null);
  272. }
  273. /**
  274. * 班级数据统计
  275. * @param Request $request
  276. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  277. * @throws \Illuminate\Validation\ValidationException
  278. * Author: Mead
  279. */
  280. public function statistical(Request $request)
  281. {
  282. $this->validate($request, [
  283. 'organization_id' => 'required|integer',
  284. ], [], ['organization_id' => '班级']);
  285. $organization_id = $request->get('organization_id');
  286. $student_ids = OrganizationStudent::query()->where('organization_id', $organization_id)->where('status', ModelStatusEnum::OK)->pluck('user_id');
  287. $course_ids = OrganizationCourse::query()->where('organization_id', $organization_id)->pluck('course_id');
  288. $student_nums = count($student_ids);
  289. $course_nums = count($course_ids);
  290. $study_total_time = ceil(UserVideoWatchRecord::query()->whereIn('course_id', $course_ids)->whereIn('user_id', $student_ids)->sum('watch_seconds') / 60);
  291. $study_average_time = 0;
  292. if ($student_nums) {
  293. $study_average_time = ceil($study_total_time / $student_nums);
  294. }
  295. $course_name = [];
  296. $names = Course::query()->whereIn('id', $course_ids)->pluck('title', 'id');
  297. $course_study = [];
  298. foreach ($course_ids as $course_id) {
  299. if (isset($names[$course_id])) {
  300. $course_name[] = $names[$course_id];
  301. $total_nums = UserRecord::query()->where('course_id', $course_id)->where('is_watched', 1)->count();
  302. $course_study[] = [
  303. 'id' => $course_id,
  304. 'name' => $names[$course_id],
  305. 'progress' => $student_nums ? bcdiv($total_nums, $student_nums, 1) : 0
  306. ];
  307. }
  308. }
  309. //统计学生完成度
  310. $student_study = [];
  311. foreach ($student_ids as $student_id) {
  312. $study_record = UserRecord::query()->whereIn('course_id', $course_ids)->where('user_id', $student_id)->select(['is_watched', 'progress', 'course_id'])->get()->keyBy('course_id')->toArray();
  313. $student_study_keys = array_keys($study_record);
  314. $study = [];
  315. foreach ($course_ids as $key => $course_id) {
  316. if (isset($course_name[$key])) {
  317. $name = $course_name[$key];
  318. if (in_array($course_id, $student_study_keys)) {
  319. $record = $study_record[$course_id];
  320. $study[] = [
  321. 'status' => $record['is_watched'] + 1,
  322. 'progress' => $record['progress'],
  323. 'name' => $name
  324. ];
  325. } else {
  326. $study[] = [
  327. 'status' => 0,
  328. 'progress' => 0,
  329. 'name' => $name
  330. ];
  331. }
  332. }
  333. }
  334. $student_study[] = [
  335. 'id' => $student_id,
  336. 'name' => User::query()->where('id', $student_id)->value('name'),
  337. 'study' => $study
  338. ];
  339. }
  340. return Response::success(compact('student_nums', 'course_nums', 'study_total_time', 'study_average_time', 'student_study', 'course_study'));
  341. }
  342. /**
  343. * 班级师资
  344. * @param Request $request
  345. * @param UserRepository $repository
  346. * @return \Illuminate\Http\JsonResponse|\Illuminate\Http\Resources\Json\Resource
  347. * @throws \Illuminate\Validation\ValidationException
  348. * Author: Mead
  349. */
  350. public function teacher(Request $request, UserRepository $repository)
  351. {
  352. $this->validate($request, [
  353. 'organization_id' => 'required|integer',
  354. ], [], ['organization_id' => '班级']);
  355. $organization_id = $request->get('organization_id');
  356. $course_ids = OrganizationCourse::query()->where('organization_id', $organization_id)->distinct()->pluck('course_id');
  357. $user_ids = Course::query()->whereIn('id', $course_ids)->distinct()->pluck('user_id');
  358. $lists = $repository->where('id', 'in', $user_ids)->get();
  359. return Response::success($lists);
  360. }
  361. }