fix: 产品推荐列表及导出问题
All checks were successful
Gitea Actions Official-website / deploy-dev (push) Successful in 3s

This commit is contained in:
2026-03-27 17:43:41 +08:00
parent 863fdda9a5
commit be26f2d75b
2 changed files with 16 additions and 11 deletions

View File

@@ -20,15 +20,17 @@ class ProductCategoryRecommend
$image_host = $server['REQUEST_SCHEME'] . "://" . $server['SERVER_NAME'] . '/';
$param = request()->get([
'keywords',
'category_name',
'page/d' => 1,
'size/d' => 10
]);
// 查询数据
$data = ProductCategoryRecommendModel::with(['category' => function($query) {
$query->field(['id', 'name']);
$data = ProductCategoryRecommendModel::withJoin(['category' => function($query) use ($param) {
if (!empty($param['category_name'])) {
$query->where('category.name', 'like', '%' . $param['category_name'] . '%');
}
}])
->withoutField(['language_id', 'updated_at', 'deleted_at'])
->withSearch(['keywords'], ['keywords' => $param['keywords']??null])
->language(request()->lang_id)
->order(['sort' => 'asc', 'id' => 'desc'])
@@ -37,7 +39,7 @@ class ProductCategoryRecommend
'page' => $param['page'],
])
->bindAttr('category', ['category_name' => 'name'])
->hidden(['category'])
->hidden(['category', 'language_id', 'updated_at', 'deleted_at'])
?->each(function($item) use($image_host) {
// 拼接完整图片URL
if (!empty($item['image'])) {
@@ -78,15 +80,18 @@ class ProductCategoryRecommend
$param = request()->get(['keywords']);
// 查询数据
return ProductCategoryRecommendModel::with(['category' => function($query) {
$query->field(['id', 'name']);
return ProductCategoryRecommendModel::withJoin(['category' => function($query) use ($param) {
if (!empty($param['category_name'])) {
$query->where('category.name', 'like', '%' . $param['category_name'] . '%');
}
}])
->withoutField(['language_id', 'updated_at', 'deleted_at'])
->withSearch(['keywords'], ['keywords' => $param['keywords']??null])
->language(request()->lang_id)
->order(['sort' => 'asc', 'id' => 'desc'])
->select()
->each(function($item) use($image_host) {
->bindAttr('category', ['category_name' => 'name'])
->hidden(['category', 'language_id', 'updated_at', 'deleted_at'])
?->each(function($item) use($image_host) {
// 拼接完整图片URL
if (!empty($item['image'])) {
$item['image'] = url_join($image_host, $item['image']);

View File

@@ -32,7 +32,7 @@ class ProductCategoryRecommendModel extends ProductCategoryRecommendBaseModel
// 所属语言范围查询
public function scopeLanguage($query, $language)
{
$query->where('language_id', '=', $language);
$query->where($this->getTable() . '.language_id', '=', $language);
}
// 关键词搜索
@@ -41,7 +41,7 @@ class ProductCategoryRecommendModel extends ProductCategoryRecommendBaseModel
if (is_null($keywords)) {
return;
}
$query->where('title', 'like', "%{$keywords}%")
->whereOr('desc', 'like', "%{$keywords}%");
$query->where($this->getTable() . '.title', 'like', "%{$keywords}%")
->whereOr($this->getTable() . '.desc', 'like', "%{$keywords}%");
}
}