79 lines
2.6 KiB
PHP
79 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace App\Endpoint\Api\Http\Controllers\Product;
|
|
|
|
use App\Endpoint\Api\Http\Controllers\Controller;
|
|
use App\Endpoint\Api\Http\Resources\ProductSku\ProductSkuSimpleResource;
|
|
use App\Helpers\Paginator as PaginatorHelper;
|
|
use App\Models\ProductPart;
|
|
use App\Models\ProductPartSku;
|
|
use App\Models\ProductSku;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Pagination\Paginator;
|
|
|
|
class ProductController extends Controller
|
|
{
|
|
/**
|
|
* 筛选商品
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function index(Request $request)
|
|
{
|
|
$skus = $request->filled('part')
|
|
? $this->filterProductsByPart($request)
|
|
: $this->filterProducts($request);
|
|
|
|
return ProductSkuSimpleResource::collection($skus);
|
|
}
|
|
|
|
/**
|
|
* 过滤商品
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @return \Illuminate\Pagination\Paginator
|
|
*/
|
|
protected function filterProducts(Request $request): Paginator
|
|
{
|
|
$input = $request->input();
|
|
|
|
if ($request->isNotFilled('sort')) {
|
|
$input['sort'] = '-id';
|
|
}
|
|
|
|
return ProductSku::select(['id', 'name', 'cover', 'sell_price', 'vip_price', 'sales'])
|
|
->filter($input)
|
|
->isRelease()
|
|
->whereRelation('category', 'is_show', true)
|
|
->simplePaginate(PaginatorHelper::resolvePerPage('per_page', 20, 50));
|
|
}
|
|
|
|
/**
|
|
* 按分区过滤商品
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @return \Illuminate\Pagination\Paginator
|
|
*/
|
|
protected function filterProductsByPart(Request $request): Paginator
|
|
{
|
|
$productPart = ProductPart::where('key', $request->input('part'))->first();
|
|
|
|
if ($productPart === null) {
|
|
return new Paginator([], $this->getPerPage($request), Paginator::resolveCurrentPage());
|
|
}
|
|
|
|
$paginator = ProductPartSku::with('sku:id,name,cover,sell_price,vip_price,sales')
|
|
->whereHas('sku', function ($query) {
|
|
$query->isRelease()->whereRelation('category', 'is_show', true);
|
|
})
|
|
->where('part_id', $productPart->id)
|
|
->latest('sort')
|
|
->simplePaginate(PaginatorHelper::resolvePerPage('per_page', 20, 50));
|
|
|
|
return $paginator->through(function ($item) {
|
|
return $item->sku;
|
|
});
|
|
}
|
|
}
|