mirror of
https://github.com/lkddi/nexusphp.git
synced 2026-04-28 06:57:22 +08:00
SearchBoxRepository
This commit is contained in:
@@ -7,6 +7,7 @@ use App\Models\ExamProgress;
|
|||||||
use App\Models\ExamUser;
|
use App\Models\ExamUser;
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
use App\Repositories\ExamRepository;
|
use App\Repositories\ExamRepository;
|
||||||
|
use App\Repositories\SearchBoxRepository;
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
use Illuminate\Support\Facades\DB;
|
use Illuminate\Support\Facades\DB;
|
||||||
@@ -61,7 +62,10 @@ class Test extends Command
|
|||||||
// $r = $disk->put('/', base_path('composer.json'));
|
// $r = $disk->put('/', base_path('composer.json'));
|
||||||
// $r = DB::table('users')->where('id', 1)->update(['modcomment' => DB::raw("concat_ws(',', 'ddddd', modcomment)")]);
|
// $r = DB::table('users')->where('id', 1)->update(['modcomment' => DB::raw("concat_ws(',', 'ddddd', modcomment)")]);
|
||||||
|
|
||||||
$r = format_description('[em4] [em27]');
|
// $r = format_description('[em4] [em27]');
|
||||||
|
|
||||||
|
$rep = new SearchBoxRepository();
|
||||||
|
$r = $rep->initSearchBoxField(4);
|
||||||
dd($r);
|
dd($r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -76,15 +76,18 @@ class Handler extends ExceptionHandler
|
|||||||
protected function prepareJsonResponse($request, Throwable $e)
|
protected function prepareJsonResponse($request, Throwable $e)
|
||||||
{
|
{
|
||||||
$data = $request->all();
|
$data = $request->all();
|
||||||
if (config('app.debug')) {
|
$httpStatusCode = $this->getHttpStatusCode($e);
|
||||||
|
if ($httpStatusCode == 200) {
|
||||||
$msg = $e->getMessage() ?: get_class($e);
|
$msg = $e->getMessage() ?: get_class($e);
|
||||||
$data['trace'] = $e->getTraceAsString();
|
|
||||||
} else {
|
} else {
|
||||||
$msg = 'Server Error';
|
$msg = 'Server Error';
|
||||||
}
|
}
|
||||||
|
if (config('app.debug')) {
|
||||||
|
$data['trace'] = $e->getTraceAsString();
|
||||||
|
}
|
||||||
return new JsonResponse(
|
return new JsonResponse(
|
||||||
fail($msg, $data),
|
fail($msg, $data),
|
||||||
$this->getHttpStatusCode($e),
|
$httpStatusCode,
|
||||||
$this->isHttpException($e) ? $e->getHeaders() : [],
|
$this->isHttpException($e) ? $e->getHeaders() : [],
|
||||||
JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES
|
JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -5,5 +5,7 @@ namespace App\Models;
|
|||||||
|
|
||||||
class Category extends NexusModel
|
class Category extends NexusModel
|
||||||
{
|
{
|
||||||
|
protected $table = 'categories';
|
||||||
|
|
||||||
|
protected $fillable = ['mode', 'name', 'class_name', 'image', 'sort_index', 'icon_id'];
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
namespace App\Models;
|
namespace App\Models;
|
||||||
|
|
||||||
class Searchbox extends NexusModel
|
class SearchBox extends NexusModel
|
||||||
{
|
{
|
||||||
protected $table = 'searchbox';
|
protected $table = 'searchbox';
|
||||||
|
|
||||||
@@ -12,4 +12,17 @@ class Searchbox extends NexusModel
|
|||||||
'custom_fields', 'custom_fields_display_name', 'custom_fields_display'
|
'custom_fields', 'custom_fields_display_name', 'custom_fields_display'
|
||||||
];
|
];
|
||||||
|
|
||||||
|
public function categories(): \Illuminate\Database\Eloquent\Relations\HasMany
|
||||||
|
{
|
||||||
|
return $this->hasMany(Category::class, 'mode');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function normal_fields(): \Illuminate\Database\Eloquent\Relations\HasMany
|
||||||
|
{
|
||||||
|
return $this->hasMany(SearchBoxField::class, 'searchbox_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,40 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
class SearchBoxField extends NexusModel
|
||||||
|
{
|
||||||
|
protected $table = 'searchbox_fields';
|
||||||
|
|
||||||
|
protected $fillable = ['searchbox_id', 'field_type', 'field_id', ];
|
||||||
|
|
||||||
|
const FIELD_TYPE_SOURCE = 'source';
|
||||||
|
const FIELD_TYPE_MEDIUM = 'medium';
|
||||||
|
const FIELD_TYPE_CODEC = 'codec';
|
||||||
|
const FIELD_TYPE_AUDIO_CODEC = 'audio_codec';
|
||||||
|
const FIELD_TYPE_STANDARD = 'standard';
|
||||||
|
const FIELD_TYPE_PROCESSING = 'processing';
|
||||||
|
const FIELD_TYPE_TEAM = 'team';
|
||||||
|
const FIELD_TYPE_CUSTOM = 'custom';
|
||||||
|
|
||||||
|
public static $fieldTypes = [
|
||||||
|
self::FIELD_TYPE_SOURCE => ['text' => 'Source', 'model' => Source::class],
|
||||||
|
self::FIELD_TYPE_MEDIUM => ['text' => 'Medium', 'model' => Media::class],
|
||||||
|
self::FIELD_TYPE_CODEC => ['text' => 'Codec', 'model' => Codec::class],
|
||||||
|
self::FIELD_TYPE_AUDIO_CODEC => ['text' => 'Audio codec', 'model' => AudioCodec::class],
|
||||||
|
self::FIELD_TYPE_STANDARD => ['text' => 'Standard', 'model' => Standard::class],
|
||||||
|
self::FIELD_TYPE_PROCESSING => ['text' => 'Processing', 'model' => Processing::class],
|
||||||
|
self::FIELD_TYPE_TEAM => ['text' => 'Team', 'model' => Team::class],
|
||||||
|
self::FIELD_TYPE_CUSTOM => ['text' => 'Custom', ],
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
public function searchBox(): \Illuminate\Database\Eloquent\Relations\BelongsTo
|
||||||
|
{
|
||||||
|
return $this->belongsTo(SearchBox::class, 'searchbox_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
namespace App\Models;
|
|
||||||
|
|
||||||
class SearchboxField extends NexusModel
|
|
||||||
{
|
|
||||||
protected $table = 'searchbox_fields';
|
|
||||||
|
|
||||||
protected $fillable = ['searchbox_id', 'field_type', 'field_id', ];
|
|
||||||
|
|
||||||
public function searchbox()
|
|
||||||
{
|
|
||||||
return $this->belongsTo(Searchbox::class, 'searchbox_id');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,84 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Repositories;
|
||||||
|
|
||||||
|
use App\Models\NexusModel;
|
||||||
|
use App\Models\SearchBox;
|
||||||
|
use App\Models\SearchBoxField;
|
||||||
|
|
||||||
|
class SearchBoxRepository extends BaseRepository
|
||||||
|
{
|
||||||
|
public function getList(array $params): \Illuminate\Contracts\Pagination\LengthAwarePaginator
|
||||||
|
{
|
||||||
|
$query = SearchBox::query();
|
||||||
|
list($sortField, $sortType) = $this->getSortFieldAndType($params);
|
||||||
|
$query->orderBy($sortField, $sortType);
|
||||||
|
return $query->paginate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function store(array $params)
|
||||||
|
{
|
||||||
|
$result = SearchBox::query()->create($params);
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function update(array $params, $id)
|
||||||
|
{
|
||||||
|
$result = SearchBox::query()->findOrFail($id);
|
||||||
|
$result->update($params);
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDetail($id)
|
||||||
|
{
|
||||||
|
$result = SearchBox::query()->findOrFail($id);
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function delete($id)
|
||||||
|
{
|
||||||
|
$result = SearchBox::query()->findOrFail($id);
|
||||||
|
$success = $result->delete();
|
||||||
|
return $success;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function buildSearchBox($id)
|
||||||
|
{
|
||||||
|
$searchBox = SearchBox::query()->with(['categories', 'normal_fields'])->findOrFail($id);
|
||||||
|
$fieldData = [];
|
||||||
|
foreach ($searchBox->normal_fields as $normalField) {
|
||||||
|
$fieldType = $normalField->field_type;
|
||||||
|
$info = SearchBoxField::$fieldTypes[$fieldType] ?? null;
|
||||||
|
if ($info) {
|
||||||
|
/** @var NexusModel $model */
|
||||||
|
$model = new $info[$fieldType]['model'];
|
||||||
|
$fieldData[$fieldType] = $model::query()->get();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$searchBox->setRelation('normal_fields_data', $fieldData);
|
||||||
|
return $searchBox;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function initSearchBoxField($id)
|
||||||
|
{
|
||||||
|
$searchBox = SearchBox::query()->findOrFail($id);
|
||||||
|
foreach (SearchBoxField::$fieldTypes as $fieldType => $info) {
|
||||||
|
if ($fieldType == SearchBoxField::FIELD_TYPE_CUSTOM) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$name = str_replace('_', '', "show{$fieldType}");
|
||||||
|
$log = "name: $name, fieldType: $fieldType";
|
||||||
|
$searchBox->normal_fields()->where('field_type', $fieldType)->delete();
|
||||||
|
if ($searchBox->{$name}) {
|
||||||
|
$searchBox->normal_fields()->create([
|
||||||
|
'field_type' => $fieldType,
|
||||||
|
]);
|
||||||
|
do_log("$log, create.");
|
||||||
|
} else {
|
||||||
|
do_log("$log, delete.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -8,7 +8,7 @@ $lang_admanage = array
|
|||||||
'text_header' => "Header",
|
'text_header' => "Header",
|
||||||
'text_footer' => "Footer",
|
'text_footer' => "Footer",
|
||||||
'text_below_navigation' => "Below Navigation",
|
'text_below_navigation' => "Below Navigation",
|
||||||
'text_below_searchbox' => "Below Searchbox",
|
'text_below_searchbox' => "Below SearchBox",
|
||||||
'text_torrent_detail' => "Torrent Detail",
|
'text_torrent_detail' => "Torrent Detail",
|
||||||
'text_comment_page' => "Comment Page",
|
'text_comment_page' => "Comment Page",
|
||||||
'text_inter_overforums' => "Inter Overforums",
|
'text_inter_overforums' => "Inter Overforums",
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ $lang_catmanage = array
|
|||||||
'head_category_management' => "Category Management",
|
'head_category_management' => "Category Management",
|
||||||
'text_category_management' => "Category Management",
|
'text_category_management' => "Category Management",
|
||||||
'text_manage' => "Manage",
|
'text_manage' => "Manage",
|
||||||
'text_searchbox' => "Searchbox",
|
'text_searchbox' => "SearchBox",
|
||||||
'text_category_icons' => "Category icon pack",
|
'text_category_icons' => "Category icon pack",
|
||||||
'text_second_icons' => "Second icons",
|
'text_second_icons' => "Second icons",
|
||||||
'text_categories' => "Categories",
|
'text_categories' => "Categories",
|
||||||
@@ -49,7 +49,7 @@ $lang_catmanage = array
|
|||||||
'submit_submit' => "Submit",
|
'submit_submit' => "Submit",
|
||||||
'text_subcategory_name_note' => "Don't use long name. Recommend less than 10 letters.",
|
'text_subcategory_name_note' => "Don't use long name. Recommend less than 10 letters.",
|
||||||
'text_order_note' => "Ascendantly, i.e. '0' comes first.",
|
'text_order_note' => "Ascendantly, i.e. '0' comes first.",
|
||||||
'row_searchbox_name' => "Searchbox Name",
|
'row_searchbox_name' => "SearchBox Name",
|
||||||
'text_searchbox_name_note' => "Allowed Characters: [a-z] (in lower case), [0-9], [_./].",
|
'text_searchbox_name_note' => "Allowed Characters: [a-z] (in lower case), [0-9], [_./].",
|
||||||
'row_show_sub_category' => "Show sub-category",
|
'row_show_sub_category' => "Show sub-category",
|
||||||
'text_show_sub_category_note' => "Check the sub-categories you want to enable.",
|
'text_show_sub_category_note' => "Check the sub-categories you want to enable.",
|
||||||
|
|||||||
@@ -15,9 +15,9 @@ return [
|
|||||||
'basic_team' => '制作组',
|
'basic_team' => '制作组',
|
||||||
'size' => '大小',
|
'size' => '大小',
|
||||||
'comments_label' => '评论',
|
'comments_label' => '评论',
|
||||||
'times_completed_label' => '完成次数',
|
'times_completed_label' => '完成',
|
||||||
'peers_count_label' => '同伴',
|
'peers_count_label' => '同伴',
|
||||||
'thank_users_count_label' => '说谢谢',
|
'thank_users_count_label' => '谢谢',
|
||||||
'numfiles_label' => '文件',
|
'numfiles_label' => '文件',
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
|
|||||||
Reference in New Issue
Block a user