Refactor product relations to use new category_product and channel_product tables

- Updated queries and relationships in various controllers and models to replace `product_has_relations` with `category_product` and `channel_product`.
- Adjusted methods in `ProductFilterer`, `FilterParamsController`, and `FilterController` to reflect the new database structure.
- Modified seeder to insert data into the new `channel_product` table.
- Updated tests to ensure compatibility with the new product relation structure.
This commit is contained in:
Mekan1206
2026-02-09 00:48:22 +05:00
parent 683fa5e0d9
commit 522ebdae34
15 changed files with 102 additions and 48 deletions

View File

@@ -81,11 +81,10 @@ class ProductFilterer
$this->queryBuilder->whereIn(
column: 'id',
values: (
fn ($query) => $query->from('product_has_relations')
fn ($query) => $query->from('category_product')
->select('product_id')
->distinct('product_id')
->where('productable_type', '=', 'category')
->whereIn('productable_id', explode(',', $this->request->categories))
->whereIn('category_id', explode(',', $this->request->categories))
)
);
}

View File

@@ -38,10 +38,9 @@ class FilterParamsController extends Controller
$category_id = (int) $request->category_id;
$brand_ids = DB::table('products')
->join('product_has_relations', function ($join) use ($category_id) {
$join->on('products.id', '=', 'product_has_relations.product_id')
->where('product_has_relations.productable_id', '=', $category_id)
->where('product_has_relations.productable_type', '=', 'category');
->join('category_product', function ($join) use ($category_id) {
$join->on('products.id', '=', 'category_product.product_id')
->where('category_product.category_id', '=', $category_id);
})
->select(['id', 'brand_id'])
->pluck('brand_id');

View File

@@ -97,9 +97,8 @@ class FilterController extends Controller
->distinct('products.id')
->pluck('products.id');
return Category::where('is_visible', true)->ordered()->join('product_has_relations', 'categories.id', '=', 'product_has_relations.productable_id')
->where('product_has_relations.productable_type', '=', 'category')
->whereIntegerInRaw('product_has_relations.product_id', $products)
return Category::where('is_visible', true)->ordered()->join('category_product', 'categories.id', '=', 'category_product.category_id')
->whereIntegerInRaw('category_product.product_id', $products)
->get(['id', 'parent_id', 'name'])
->unique('categories.id');
}

View File

@@ -87,9 +87,8 @@ class CategoriesFilter
->distinct('products.id')
->pluck('products.id');
return $this->queryBuilder->join('product_has_relations', 'categories.id', '=', 'product_has_relations.productable_id')
->where('product_has_relations.productable_type', '=', 'category')
->whereIntegerInRaw('product_has_relations.product_id', $products)
return $this->queryBuilder->join('category_product', 'categories.id', '=', 'category_product.category_id')
->whereIntegerInRaw('category_product.product_id', $products)
->get($this->columns)
->unique('categories.id');
}

View File

@@ -16,18 +16,17 @@ class ProductRelatedController extends Controller
*/
public function index(Product $product): JsonResponse
{
$products = DB::table('product_has_relations')
->select('product_has_relations.product_id')
->whereIn('product_has_relations.productable_id', (function ($query) use ($product) {
$query->from('product_has_relations')
->select('productable_id')
->distinct('productable_id')
->where('productable_type', '=', 'category')
$products = DB::table('category_product')
->select('category_product.product_id')
->whereIn('category_product.category_id', (function ($query) use ($product) {
$query->from('category_product')
->select('category_id')
->distinct('category_id')
->where('product_id', '=', $product->id);
}))
->limit(12)
->orderByRaw('RANDOM()')
->pluck('product_has_relations.product_id')
->pluck('category_product.product_id')
->unique();
return response()->rest(

View File

@@ -11,6 +11,7 @@ use App\Repositories\System\Cache\CacheRepository;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Database\Eloquent\Relations\MorphTo;
use Illuminate\Database\Eloquent\Relations\MorphToMany;
@@ -179,9 +180,9 @@ class Channel extends Model implements HasMedia, Sortable
/**
* Products
*/
public function products(): MorphToMany
public function products(): BelongsToMany
{
return $this->morphToMany(Product::class, 'productable', 'product_has_relations');
return $this->belongsToMany(Product::class, 'channel_product');
}
/**

View File

@@ -152,9 +152,9 @@ class Category extends Model implements HasMedia, Sortable
/**
* Category Products
*/
public function products(): MorphToMany
public function products(): BelongsToMany
{
return $this->morphToMany(Product::class, 'productable', 'product_has_relations');
return $this->belongsToMany(Product::class, 'category_product');
}
/**

View File

@@ -5,6 +5,7 @@ namespace App\Models\Ecommerce\Product\Collection;
use App\Models\Ecommerce\Product\Product\Product;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
use Illuminate\Database\Eloquent\Relations\MorphToMany;
use Spatie\EloquentSortable\Sortable;
use Spatie\EloquentSortable\SortableTrait;
@@ -109,9 +110,9 @@ class Collection extends Model implements HasMedia, Sortable
/**
* Products
*/
public function products(): MorphToMany
public function products(): BelongsToMany
{
return $this->morphToMany(Product::class, 'productable', 'product_has_relations');
return $this->belongsToMany(Product::class, 'collection_product');
}
/**

View File

@@ -38,9 +38,9 @@ trait ProductRelationships
/**
* Related Channels
*/
public function channels(): MorphToMany
public function channels(): BelongsToMany
{
return $this->morphedByMany(Channel::class, 'productable', 'product_has_relations');
return $this->belongsToMany(Channel::class, 'channel_product');
}
/**
@@ -56,25 +56,25 @@ trait ProductRelationships
/**
* Related products (similar)
*/
public function relatedProducts(): MorphToMany
public function relatedProducts(): BelongsToMany
{
return $this->morphedByMany(Product::class, 'productable', 'product_has_relations');
return $this->belongsToMany(Product::class, 'product_related', 'product_id', 'related_product_id');
}
/**
* Related categories
*/
public function categories(): MorphToMany
public function categories(): BelongsToMany
{
return $this->morphedByMany(Category::class, 'productable', 'product_has_relations');
return $this->belongsToMany(Category::class, 'category_product');
}
/**
* Related Collections
*/
public function collections(): MorphToMany
public function collections(): BelongsToMany
{
return $this->morphedByMany(Collection::class, 'productable', 'product_has_relations');
return $this->belongsToMany(Collection::class, 'collection_product');
}
/**

View File

@@ -33,9 +33,8 @@ class ProductEntrepreneurFilter extends Filter
*/
public function apply(NovaRequest $request, $query, $value)
{
$vendorProducts = DB::table('product_has_relations')
->where('productable_type', 'channel')
->where('productable_id', $value)
$vendorProducts = DB::table('channel_product')
->where('channel_id', $value)
->pluck('product_id');
$query->whereIntegerInRaw('id', $vendorProducts);

View File

@@ -123,9 +123,8 @@ class Product extends Resource
$user = $request->user();
if ($user->hasRole('vendor')) {
$vendorProducts = DB::table('product_has_relations')
->where('productable_type', 'channel')
->where('productable_id', $user->channel()->id)
$vendorProducts = DB::table('channel_product')
->where('channel_id', $user->channel()->id)
->pluck('product_id');
$query->whereIntegerInRaw('id', $vendorProducts);

View File

@@ -182,9 +182,8 @@ class CategoryRepository
])) {
$products = $resource->products()->distinct('products.id')->pluck('products.id');
return $this->queryBuilder->join('product_has_relations', 'categories.id', '=', 'product_has_relations.productable_id')
->where('product_has_relations.productable_type', '=', 'category')
->whereIntegerInRaw('product_has_relations.product_id', $products)
return $this->queryBuilder->join('category_product', 'categories.id', '=', 'category_product.category_id')
->whereIntegerInRaw('category_product.product_id', $products)
->distinct('categories.id')
->get(['id', 'slug', 'name']);
}