upload/section add tags

This commit is contained in:
xiaomlove
2025-02-18 02:15:30 +08:00
parent c9b2237efd
commit 7b3e74b47e
4 changed files with 33 additions and 16 deletions
+6 -1
View File
@@ -21,7 +21,9 @@ class SearchBoxResource extends JsonResource
'id' => $this->id,
'name' => $this->displaySectionName,
'categories' => CategoryResource::collection($this->whenLoaded('categories')),
'tags' => TagResource::collection($this->whenLoaded('tags')),
];
if ($searchBox->showsubcat) {
$subCategories = [];
$lang = get_langfolder_cookie();
$fields = array_keys(SearchBox::$taxonomies);
@@ -38,7 +40,10 @@ class SearchBoxResource extends JsonResource
];
}
}
$out['sub_categories'] = $this->when($this->showsubcat, $subCategories);
if (!empty($subCategories)) {
$out['sub_categories'] = $subCategories;
}
}
return $out;
}
}
+11
View File
@@ -3,6 +3,7 @@
namespace App\Models;
use App\Http\Middleware\Locale;
use App\Repositories\TagRepository;
use Illuminate\Database\Eloquent\Casts\Attribute;
use Illuminate\Database\Query\Builder;
use Illuminate\Support\Str;
@@ -288,6 +289,16 @@ class SearchBox extends NexusModel
}
}
public function tags(): \Illuminate\Database\Eloquent\Relations\HasMany
{
return $this->hasMany(Tag::class, 'mode');
}
public function loadTags(): void
{
$this->setRelation("tags", TagRepository::listAll($this->id));
}
public static function getDefaultSearchMode()
{
$meiliConf = get_setting("meilisearch");
+1
View File
@@ -254,6 +254,7 @@ class SearchBoxRepository extends BaseRepository
if ($searchBox->showsubcat) {
$searchBox->loadSubCategories();
}
$searchBox->loadTags();
}
return $searchBoxList;
}
+1 -1
View File
@@ -149,7 +149,7 @@ class TagRepository extends BaseRepository
return self::$orderByFieldIdString;
}
public function listAll(int $searchBoxId = 0): \Illuminate\Database\Eloquent\Collection|array
public static function listAll(int $searchBoxId = 0): \Illuminate\Database\Eloquent\Collection|array
{
if (empty(self::$allTags)) {
self::$allTags = self::createBasicQuery()->get();