StudentController.php 5.2 KB

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