Pergunta

A função abaixo recebe um id de usuário e obter os itens do usuário da lista de observação.Existe uma maneira que eu possa adicionar a seguinte lógica para um ponto de vista?A linha de comentário tem a ver que eu estou tentando passar para.

public function getWatchList() {

    $user = User::find(Auth::user()->id);
    $item = WatchList::where('user_id', '=', $user->id)->get();

     foreach ($item as $i) {
        $items = Catagory::where('id', '=', $i->item_id)->get();

            foreach ($items as $item) {
                echo $item->id;
            }
     }

    // return View::make('account.watchlist')
    //     ->with('items', $items);
}
Foi útil?

Solução

// don't need that, unnecessary db call, twice..
// $user = User::find(Auth::user()->id);

// you can do this:
$categoriesIds = WatchList::where('user_id', '=', Auth::id())->lists('item_id');

// then
$categories = Category::whereIn('id', $categoriesIds)->get();

return View::make('account.watchlist')->with('categories', $categories);

Visualizar modelo (account/watchlist.blade.php):

@foreach ($categories as $category)
   {{ $category->id }}
@endforeach
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top