Site du proximo, utilisé pour gérer le stock.
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.

CategorieController.php 3.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Models\Categorie;
  4. use Illuminate\Http\Request;
  5. use Illuminate\Support\Facades\Storage;
  6. use Illuminate\Support\Facades\Validator;
  7. use App\Http\Validation\CategorieValidation;
  8. class CategorieController extends Controller
  9. {
  10. /**
  11. * Display a listing of the resource.
  12. *
  13. * @return \Illuminate\Http\Response
  14. */
  15. public function index()
  16. {
  17. $categories = Categorie::all();
  18. // Renvoie le nombre d'articles par categorie
  19. for($i = 0; $i < count($categories); ++$i) {
  20. $categories[$i]['nb_articles'] += Article::where('category_id','=',$categories[$i]->id)->count();
  21. }
  22. return response()->json($categories);
  23. }
  24. /**
  25. * Show the form for creating a new resource.
  26. *
  27. * @return \Illuminate\Http\Response
  28. */
  29. public function create()
  30. {
  31. //
  32. }
  33. /**
  34. * Store a newly created resource in storage.
  35. *
  36. * @param \Illuminate\Http\Request $request
  37. * @return \Illuminate\Http\Response
  38. */
  39. public function store(Request $request, CategorieValidation $validation)
  40. {
  41. $validator = Validator::make($request->all(), $validation->rules(), $validation->messages());
  42. if($validator->fails()){
  43. return response()->json(['errors' => $validator->errors()],401);
  44. }
  45. $fullFileName = $request->file('icon')->getClientOriginalName();
  46. $fileName = pathinfo($fullFileName, PATHINFO_FILENAME);
  47. $extension = $request->file('icon')->getClientOriginalExtension();
  48. $file = $fileName.'_'.time().'.'.$extension;
  49. $request->file('icon')->storeAs('public/icon',$file);
  50. $categorie = Categorie::create([
  51. 'name' => $request->input('name'),
  52. 'icon' => $file
  53. ]);
  54. return response()->json($categorie);
  55. }
  56. /**
  57. * Store a newly created resource in storage.
  58. *
  59. * @param \Illuminate\Http\Request $request
  60. * @return \Illuminate\Http\Response
  61. */
  62. public function updateImage(Request $request, $id) {
  63. $category = Categorie::find($id);
  64. $fullFileName = $request->file('icon')->getClientOriginalName();
  65. $fileName = pathinfo($fullFileName, PATHINFO_FILENAME);
  66. $extension = $request->file('icon')->getClientOriginalExtension();
  67. $file = $fileName.'_'.time().'.'.$extension;
  68. $request->file('icon')->storeAs('public/icon',$file);
  69. $icon = $category->icon;
  70. Storage::delete('public/icon/'.$icon);
  71. $category->icon = $file;
  72. $category->save();
  73. }
  74. /**
  75. * Display the specified resource.
  76. *
  77. * @param int $id
  78. * @return \Illuminate\Http\Response
  79. */
  80. public function show($id)
  81. {
  82. //
  83. }
  84. /**
  85. * Show the form for editing the specified resource.
  86. *
  87. * @param int $id
  88. * @return \Illuminate\Http\Response
  89. */
  90. public function edit($id)
  91. {
  92. //
  93. }
  94. /**
  95. * Update the specified resource in storage.
  96. *
  97. * @param \Illuminate\Http\Request $request
  98. * @param int $id
  99. * @return \Illuminate\Http\Response
  100. */
  101. public function update(Request $request, $id, CategorieValidation $validation)
  102. {
  103. $validator = Validator::make($request->all(), $validation->updateRules(), $validation->updateMessages());
  104. if($validator->fails()){
  105. return response()->json(['errors' => $validator->errors()],401);
  106. }
  107. $category = Categorie::find($id);
  108. $category->name = $request->get('name');
  109. $category->save();
  110. }
  111. /**
  112. * Remove the specified resource from storage.
  113. *
  114. * @param int $id
  115. * @return \Illuminate\Http\Response
  116. */
  117. public function destroy($id)
  118. {
  119. $category = Categorie::find($id);
  120. $icon = $category->icon;
  121. Storage::delete('public/icon/'.$icon);
  122. $category->delete();
  123. }
  124. }