mirror of
https://github.com/brunofontes/shareit.git
synced 2025-01-19 15:00:50 +00:00
58 lines
1.5 KiB
PHP
58 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use Illuminate\Http\Request;
|
|
use \App\Item;
|
|
|
|
class ItemController extends Controller
|
|
{
|
|
public function show($id)
|
|
{
|
|
$item = Item::find($id);
|
|
if (!$item || $item->product->user_id != \Auth::id()) return back();
|
|
|
|
$otherItems = Item::where([['product_id', $item->product_id], ['id', '!=', $id]])->get();
|
|
return view('item', compact('item', 'otherItems'));
|
|
}
|
|
|
|
public function index()
|
|
{
|
|
//TODO: Fazer innerjoint com tabela de users por item
|
|
$items = Item::where('user_id', \Auth::id())->get();
|
|
return view('item.index', compact('items'));
|
|
}
|
|
|
|
/**
|
|
* Stores the included item into database
|
|
* As the items are included on the Product view,
|
|
* it must return to there after inclusion
|
|
*
|
|
* @return (view) The product view
|
|
*/
|
|
public function store(Request $request)
|
|
{
|
|
$request->validate(
|
|
[
|
|
'item' => 'required',
|
|
'product_id' => 'required'
|
|
]
|
|
);
|
|
|
|
$user = \App\User::find(\Auth::id());
|
|
$user->items()->create(['name' => request('item'), 'product_id' => request('product_id')]);
|
|
|
|
return redirect('product/'.request('product_id'));
|
|
}
|
|
|
|
public function delete(Request $request)
|
|
{
|
|
$request->validate(['item' => 'required']);
|
|
$item = \App\User::find(\Auth::id())->items()->find(request('item'));
|
|
$product = $item->product_id;
|
|
$item->delete();
|
|
return redirect('product/' . $product);
|
|
}
|
|
|
|
}
|