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.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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. return response()->json($categories);
  19. }
  20. /**
  21. * Show the form for creating a new resource.
  22. *
  23. * @return \Illuminate\Http\Response
  24. */
  25. public function create()
  26. {
  27. //
  28. }
  29. /**
  30. * Store a newly created resource in storage.
  31. *
  32. * @param \Illuminate\Http\Request $request
  33. * @return \Illuminate\Http\Response
  34. */
  35. public function store(Request $request, CategorieValidation $validation)
  36. {
  37. $validator = Validator::make($request->all(), $validation->rules(), $validation->messages());
  38. if($validator->fails()){
  39. return response()->json(['errors' => $validator->errors()],401);
  40. }
  41. $fullFileName = $request->file('icon')->getClientOriginalName();
  42. $fileName = pathinfo($fullFileName, PATHINFO_FILENAME);
  43. $extension = $request->file('icon')->getClientOriginalExtension();
  44. $file = $fileName.'_'.time().'.'.$extension;
  45. $request->file('icon')->storeAs('public/icon',$file);
  46. $categorie = Categorie::create([
  47. 'name' => $request->input('name'),
  48. 'icon' => $file
  49. ]);
  50. return response()->json($categorie);
  51. }
  52. /**
  53. * Store a newly created resource in storage.
  54. *
  55. * @param \Illuminate\Http\Request $request
  56. * @return \Illuminate\Http\Response
  57. */
  58. public function updateImage(Request $request, $id) {
  59. $category = Categorie::find($id);
  60. $fullFileName = $request->file('icon')->getClientOriginalName();
  61. $fileName = pathinfo($fullFileName, PATHINFO_FILENAME);
  62. $extension = $request->file('icon')->getClientOriginalExtension();
  63. $file = $fileName.'_'.time().'.'.$extension;
  64. $request->file('icon')->storeAs('public/icon',$file);
  65. $icon = $category->icon;
  66. Storage::delete('public/icon/'.$icon);
  67. $category->icon = $file;
  68. $category->save();
  69. }
  70. /**
  71. * Display the specified resource.
  72. *
  73. * @param int $id
  74. * @return \Illuminate\Http\Response
  75. */
  76. public function show($id)
  77. {
  78. //
  79. }
  80. /**
  81. * Show the form for editing the specified resource.
  82. *
  83. * @param int $id
  84. * @return \Illuminate\Http\Response
  85. */
  86. public function edit($id)
  87. {
  88. //
  89. }
  90. /**
  91. * Update the specified resource in storage.
  92. *
  93. * @param \Illuminate\Http\Request $request
  94. * @param int $id
  95. * @return \Illuminate\Http\Response
  96. */
  97. public function update(Request $request, $id, CategorieValidation $validation)
  98. {
  99. $validator = Validator::make($request->all(), $validation->updateRules(), $validation->updateMessages());
  100. if($validator->fails()){
  101. return response()->json(['errors' => $validator->errors()],401);
  102. }
  103. $category = Categorie::find($id);
  104. $category->name = $request->get('name');
  105. $category->save();
  106. }
  107. /**
  108. * Remove the specified resource from storage.
  109. *
  110. * @param int $id
  111. * @return \Illuminate\Http\Response
  112. */
  113. public function destroy($id)
  114. {
  115. $category = Categorie::find($id);
  116. $icon = $category->icon;
  117. Storage::delete('public/icon/'.$icon);
  118. $category->delete();
  119. }
  120. }