shareit/app/Http/Controllers/ItemController.php

59 lines
1.6 KiB
PHP
Raw Normal View History

<?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();
$users = $item->users()->get();
$otherItems = Item::where([['product_id', $item->product_id], ['id', '!=', $id]])->get();
return view('item', compact('item', 'otherItems', 'users'));
}
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
*/
2018-09-11 23:48:09 +00:00
public function store(Request $request)
{
2018-09-11 23:48:09 +00:00
$request->validate(
[
'item' => 'required',
'product_id' => 'required'
]
);
$authUser = \App\User::find(\Auth::id());
$authUser->items()->create(['name' => request('item'), 'product_id' => request('product_id')]);
2018-09-11 23:48:09 +00:00
return redirect('product/'.request('product_id'));
}
2018-09-13 00:27:04 +00:00
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);
}
}