Аргумент 1, передаваемый в App \ Http \ Controllers \ ApiController :: showAll (), должен быть экземпляром Illuminate \ Database \ Eloquent \ Collection - PullRequest
0 голосов
/ 09 октября 2019

Я хочу получить всех покупателей для конкретного продавца. Когда я удаляю pluck и другие методы, цепочки после метода get, он работает. Но это не совсем то, что я хочу. Как я могу решить эту проблему?

database structure

<?php

namespace App\Http\Controllers\Seller;

use App\Http\Controllers\ApiController;
use App\Seller;
use Illuminate\Http\Request;

class SellerBuyerController extends ApiController
{

    public function index(Seller $seller)
    {
        $buyers = $seller->products()
                ->whereHas('transactions')
                ->with('transactions.buyer')
                ->get()->pluck('transactions')
                ->collapse()->pluck('buyer')
                ->unique('id')
                ->values();

        return $this->showAll($buyers);
    }

    protected function showAll(Collection $collection, $code = 200)
    {
        return $this->successResponse($collection, $code);
    }

    protected function successResponse($data, $code)
    {
        return response()->json($data, $code);
    }

}

Модель продавца имеет много связей с продуктами

<?php

namespace App;

use App\Scopes\SellerScope;

class Seller extends User
{

    public function products()
    {
        return $this->hasMany(Product::class);
    }
}

Модель товара имеет много отношений с транзакциями

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;

class Product extends Model
{
    use SoftDeletes;


    protected $fillable = [
        'name', 'description', 'quantity', 'status', 'image', 'seller_id',
    ];

    public function transactions()
    {
        return $this->hasMany(Transaction::class);
    }

}

Модель сделки и отношение к покупателю

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;

class Transaction extends Model
{
    use SoftDeletes;

    protected $fillable = [
        'quantity', 'buyer_id', 'product_id'
    ];

    public function buyer()
    {
        return $this->belongsTo(Buyer::class);
    }

}

Ответы [ 2 ]

1 голос
/ 09 октября 2019

Вам не хватает импорта вверху:

use Illuminate\Support\Collection;

в противном случае предполагается, что должен использоваться Illuminate\Database\Eloquent\Collection.

И values(), очевидно, возвращает коллекцию поддержки, а неКрасноречивый.

0 голосов
/ 09 октября 2019

Если у вас есть отношения от Buyer до Transaction, вы можете пойти по этому пути в другом направлении, чтобы найти покупателей. Вы также должны убедиться, что есть отношение от Product до Seller (убедитесь, что у вас есть обратная связь с каждой настройкой отношения)

Buyer::whereHas('transactions.products.seller', function ($query) use ($seller) {
    $query->where('id', $seller->id); // might have to be a more specific key name
})->get();

В итоге вы получите красноречивую коллекцию покупателей, которыеиметь транзакции, включая товары от конкретного продавца.

...