mirror of
https://github.com/HDInnovations/UNIT3D-Community-Edition.git
synced 2026-05-01 07:52:00 -05:00
82 lines
3.2 KiB
PHP
Executable File
82 lines
3.2 KiB
PHP
Executable File
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
/**
|
|
* NOTICE OF LICENSE.
|
|
*
|
|
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
|
|
* The details is bundled with this project in the file LICENSE.txt.
|
|
*
|
|
* @project UNIT3D Community Edition
|
|
*
|
|
* @author HDVinnie <hdinnovations@protonmail.com>
|
|
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
|
|
*/
|
|
|
|
namespace App\Http\Livewire;
|
|
|
|
use App\Models\Movie;
|
|
use App\Models\Person;
|
|
use App\Models\Tv;
|
|
use Livewire\Component;
|
|
|
|
class QuickSearchDropdown extends Component
|
|
{
|
|
public string $quicksearchRadio = 'movies';
|
|
|
|
public string $quicksearchText = '';
|
|
|
|
public function render(): \Illuminate\Contracts\View\Factory|\Illuminate\Contracts\View\View
|
|
{
|
|
$search = '%'.str_replace(' ', '%', $this->quicksearchText).'%';
|
|
|
|
return view('livewire.quick-search-dropdown', [
|
|
'search_results' => $this->quicksearchText === '' ? [] : match ($this->quicksearchRadio) {
|
|
'movies' => Movie::query()
|
|
->select(['id', 'poster', 'title', 'release_date'])
|
|
->selectRaw("concat(title, ' ', release_date) as title_and_year")
|
|
->when(
|
|
preg_match('/^\d+$/', $this->quicksearchText),
|
|
fn ($query) => $query->where('id', '=', $this->quicksearchText),
|
|
fn ($query) => $query
|
|
->when(
|
|
preg_match('/tt0*(?=(\d{7,}))/', $this->quicksearchText, $matches),
|
|
fn ($query) => $query->where('imdb_id', '=', $matches[1]),
|
|
fn ($query) => $query->having('title_and_year', 'LIKE', $search),
|
|
)
|
|
)
|
|
->has('torrents')
|
|
->oldest('title')
|
|
->take(10)
|
|
->get(),
|
|
'series' => Tv::query()
|
|
->select(['id', 'poster', 'name', 'first_air_date'])
|
|
->selectRaw("concat(name, ' ', first_air_date) as title_and_year")
|
|
->when(
|
|
preg_match('/^\d+$/', $this->quicksearchText),
|
|
fn ($query) => $query->where('id', '=', $this->quicksearchText),
|
|
fn ($query) => $query
|
|
->when(
|
|
preg_match('/tt0*(?=(\d{7,}))/', $this->quicksearchText, $matches),
|
|
fn ($query) => $query->where('imdb_id', '=', $matches[1]),
|
|
fn ($query) => $query->having('title_and_year', 'LIKE', $search),
|
|
)
|
|
)
|
|
->has('torrents')
|
|
->oldest('name')
|
|
->take(10)
|
|
->get(),
|
|
'persons' => Person::query()
|
|
->select(['id', 'still', 'name'])
|
|
->whereNotNull('still')
|
|
->where('name', 'LIKE', $search)
|
|
->oldest('name')
|
|
->take(10)
|
|
->get(),
|
|
default => [],
|
|
},
|
|
]);
|
|
}
|
|
}
|