My beer compendium
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.

133 lines
3.8 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4. use App\Models\Summarie;
  5. use Illuminate\Support\Facades\DB;
  6. class SummarieController extends Controller
  7. {
  8. public function __construct()
  9. {
  10. $this->middleware('auth');
  11. }
  12. public function index()
  13. {
  14. $beers = Summarie::orderBy('name')->get();
  15. foreach ($beers as $beer)
  16. {
  17. $brewery = DB::table('breweries')->where('id', $beer->beer_id)->value('name');
  18. $beer['brewery'] = $brewery;
  19. }
  20. return view('beers.index')->with('beers', $beers);
  21. }
  22. public function store(Request $request){
  23. // validation
  24. $this->validate($request,[
  25. 'name' => 'required',
  26. 'type' => 'required',
  27. 'abv' => 'required',
  28. 'fg' => 'required',
  29. 'keywords' => 'required',
  30. 'og' => 'required',
  31. 'source' => 'required',
  32. 'batch' => 'required',
  33. 'beer_id' => 'required',
  34. 'brewery_id' => 'required'
  35. ]);
  36. // create project
  37. $beer = new Summarie;
  38. $beer->beer_id = $request->input('beer_id');
  39. $beer->name = $request->input('name');
  40. $beer->type = $request->input('type');
  41. $beer->abv = $request->input('abv');
  42. $beer->fg = $request->input('fg');
  43. $beer->keywords = '{'.$request->input('keywords').'}';
  44. if ($request->mine)
  45. {
  46. $beer->mine = true;
  47. } else {
  48. $beer->mine = false;
  49. }
  50. $beer->og = $request->input('og');
  51. $beer->source = $request->input('source');
  52. $beer->batch = $request->input('batch');
  53. $beer->beer_id = $request->input('beer_id');
  54. $beer->brewery_id = $request->input('brewery_id');
  55. if ($request->input('notes'))
  56. {
  57. $beer->notes = $request->input('notes');
  58. }
  59. $beer->save();
  60. return redirect('/beers')->with('success', 'Beer Added');
  61. }
  62. public function edit($id){
  63. $beer = Summarie::where('beer_id', (int)$id)->first();
  64. return view('beers.edit')->with('beer', $beer);
  65. }
  66. public function update(Request $request, $id)
  67. {
  68. $request->validate([
  69. 'name' => 'required',
  70. 'type' => 'required',
  71. 'abv' => 'required',
  72. 'fg' => 'required',
  73. 'keywords' => 'required',
  74. 'og' => 'required',
  75. 'source' => 'required',
  76. 'batch' => 'required',
  77. 'brewery_id' => 'required'
  78. ]);
  79. $beer = Summarie::where('beer_id', (int)$id)->first();
  80. $beer->name = $request->input('name');
  81. $beer->type = $request->input('type');
  82. $beer->abv = $request->input('abv');
  83. $beer->fg = $request->input('fg');
  84. $beer->keywords = '{'.$request->input('keywords').'}';
  85. if ($request->mine)
  86. {
  87. $beer->mine = true;
  88. } else {
  89. $beer->mine = false;
  90. }
  91. $beer->og = $request->input('og');
  92. $beer->source = $request->input('source');
  93. $beer->batch = $request->input('batch');
  94. $beer->beer_id = $request->input('beer_id');
  95. $beer->brewery_id = $request->input('beer_id');
  96. if ($request->input('notes'))
  97. {
  98. $beer->notes = $request->input('notes');
  99. }
  100. $beer->save();
  101. return redirect('/beers')->with('success', 'Beer updated!');
  102. }
  103. public function create()
  104. {
  105. $lastID = Summarie::orderBy('beer_id','desc')->take(1)->value('beer_id');
  106. $beer_id = number_format($lastID) + 1;
  107. return view('beers.create')->with('beer_id', $beer_id);
  108. }
  109. public function destroy($id)
  110. {
  111. $beer = Summarie::find($id);
  112. $beer->delete();
  113. return redirect('/beers')->with('success', 'Beer deleted!');
  114. }
  115. }