StudentController.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. <?php
  2. namespace App\Http\Controllers\Admin\User;
  3. use App\Exports\StudentExport;
  4. use App\Http\Controllers\Controller;
  5. use App\Imports\StudentsImport;
  6. use App\Jobs\ImportStudentJob;
  7. use App\Repositories\Enums\ModelStatusEnum;
  8. use App\Repositories\Enums\ResponseCodeEnum;
  9. use App\Repositories\Models\Base\Admin;
  10. use App\Repositories\Models\Base\Resource;
  11. use App\Repositories\Models\Navigation\UserOrganization;
  12. use App\Repositories\Models\User\Student;
  13. use Illuminate\Http\Request;
  14. use Illuminate\Support\Facades\Storage;
  15. use Jiannei\Response\Laravel\Support\Facades\Response;
  16. use Maatwebsite\Excel\Facades\Excel;
  17. use Prettus\Validator\Contracts\ValidatorInterface;
  18. use App\Contracts\Repositories\User\StudentRepository;
  19. use App\Repositories\Validators\User\StudentValidator;
  20. /**
  21. * Class StudentsController.
  22. *
  23. * @package namespace App\Http\Controllers\Admin\User;
  24. */
  25. class StudentController extends Controller
  26. {
  27. /**
  28. * @var StudentRepository
  29. */
  30. protected $repository;
  31. /**
  32. * @var StudentValidator
  33. */
  34. protected $validator;
  35. /**
  36. * StudentsController constructor.
  37. *
  38. * @param StudentRepository $repository
  39. * @param StudentValidator $validator
  40. */
  41. public function __construct(StudentRepository $repository, StudentValidator $validator)
  42. {
  43. parent::__construct();
  44. $this->repository = $repository;
  45. $this->validator = $validator;
  46. }
  47. public function index()
  48. {
  49. $lists = $this->repository->paginate(request('per_page', self::PAGE_NUM));
  50. return Response::success($lists);
  51. }
  52. /**
  53. * 添加菜单
  54. * @param Request $request
  55. * Author: Mead
  56. */
  57. public function store(Request $request)
  58. {
  59. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_CREATE));
  60. if (Admin::query()->where('username', $request->get('account'))->exists()) {
  61. return Response::fail('账户已存在');
  62. }
  63. if (Student::query()->where('account', $request->get('account'))->exists()) {
  64. return Response::fail('账户已存在');
  65. }
  66. try {
  67. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_CREATE)));
  68. $student = $this->repository->create($data);
  69. return Response::success($student);
  70. } catch (\Exception $e) {
  71. return $this->error($e);
  72. }
  73. }
  74. public function update($id, Request $request)
  75. {
  76. $this->validate($request, $this->validator->getRules(ValidatorInterface::RULE_UPDATE));
  77. try {
  78. $data = $request->only(array_keys($this->validator->getRules(ValidatorInterface::RULE_UPDATE)));
  79. $student = $this->repository->update($data, $id);
  80. return Response::success($student);
  81. } catch (\Exception $e) {
  82. $this->error($e);
  83. }
  84. }
  85. public function show($id)
  86. {
  87. $courseCategory = $this->repository->find($id);
  88. return Response::success($courseCategory);
  89. }
  90. public function destroy($id)
  91. {
  92. try {
  93. $re = $this->repository->delete($id);
  94. if ($re) {
  95. return Response::success(null, T('successfully delete.'));
  96. }
  97. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  98. } catch (\Exception $exception) {
  99. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  100. }
  101. }
  102. public function delete(Request $request)
  103. {
  104. try {
  105. $this->validate($request, [
  106. 'ids' => 'required|array',
  107. ]);
  108. $ids = $request->get('ids');
  109. $this->repository->whereIn('id', $ids)->delete();
  110. return Response::success(null, T('successfully delete.'));
  111. } catch (\Exception $exception) {
  112. return Response::fail(T('Delete failed.'), ResponseCodeEnum::SERVICE_UPDATE_DATA_ERROR);
  113. }
  114. }
  115. public function import(Request $request)
  116. {
  117. $this->validate($request, [
  118. 'id' => 'required|integer',
  119. ]);
  120. $resource = Resource::query()->where('id', $request->get('id'))->first();
  121. if (!$resource) {
  122. return $this->errorFail();
  123. }
  124. // Excel::import(new StudentsImport(), Storage::disk($resource['disk'])->path($resource['path']));
  125. $this->dispatch(new ImportStudentJob($resource['disk'], $resource['path']));
  126. return Response::success(null, '正在导入,请稍后');
  127. }
  128. /**
  129. * 导出
  130. * Author: Mead
  131. */
  132. public function export(Request $request)
  133. {
  134. $this->validate($request, [
  135. 'ids' => 'required|array',
  136. 'fields' => 'sometimes|array',
  137. ]);
  138. $ids = $request->get('ids');
  139. $name = time();
  140. return (new StudentExport($request->get('fields', [0, 1, 2, 3, 4, 5, 6, 7])))->forIds($ids)->download($name . '.xlsx', null, [
  141. 'Access-Control-Allow-Origin' => '*',
  142. 'Access-Control-Allow-Methods' => '*',
  143. 'Access-Control-Allow-Headers' => 'Content-Type, Authorization, X-Requested-With',
  144. 'Access-Control-Expose-Headers' => 'Content-Disposition',
  145. 'Content-type' => 'application/octet-stream',
  146. 'Content-Disposition' => 'attachment; filename=' . $name . '.xlsx',
  147. ]);
  148. }
  149. }