mirror of
https://github.com/HDInnovations/UNIT3D-Community-Edition.git
synced 2026-01-30 15:59:28 -06:00
We already make most of these queries anyways, and we'll need these foriegn keys when implementing future forum features like 'catch up'.
98 lines
3.3 KiB
PHP
98 lines
3.3 KiB
PHP
<?php
|
|
/**
|
|
* 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 Roardom <roardom@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\Forum;
|
|
use App\Models\Subscription;
|
|
use App\Models\Topic;
|
|
use Livewire\Component;
|
|
use Livewire\WithPagination;
|
|
|
|
class ForumTopicSearch extends Component
|
|
{
|
|
use WithPagination;
|
|
|
|
public string $search = '';
|
|
public string $sortField = 'last_post_created_at';
|
|
public string $sortDirection = 'desc';
|
|
public string $label = '';
|
|
public string $state = '';
|
|
public string $subscribed = '';
|
|
public Forum $forum;
|
|
public ?Subscription $subscription;
|
|
|
|
/**
|
|
* @var array<mixed>
|
|
*/
|
|
protected $queryString = [
|
|
'search' => ['except' => ''],
|
|
'sortField' => ['except' => 'last_post_created_at'],
|
|
'sortDirection' => ['except' => 'desc'],
|
|
'label' => ['except' => ''],
|
|
'state' => ['except' => ''],
|
|
'subscribed' => ['except' => ''],
|
|
];
|
|
|
|
final public function mount(Forum $forum): void
|
|
{
|
|
$this->forum = $forum;
|
|
$this->subscription = Subscription::where('user_id', '=', auth()->id())->where('forum_id', '=', $forum->id)->first();
|
|
}
|
|
|
|
final public function updatedPage(): void
|
|
{
|
|
$this->emit('paginationChanged');
|
|
}
|
|
|
|
final public function updatingSearch(): void
|
|
{
|
|
$this->resetPage();
|
|
}
|
|
|
|
/**
|
|
* @return \Illuminate\Contracts\Pagination\LengthAwarePaginator<Topic>
|
|
*/
|
|
final public function getTopicsProperty(): \Illuminate\Contracts\Pagination\LengthAwarePaginator
|
|
{
|
|
return Topic::query()
|
|
->select('topics.*')
|
|
->with('user', 'user.group', 'latestPoster', 'forum:id,name')
|
|
->where('topics.forum_id', '=', $this->forum->id)
|
|
->whereRelation('forumPermissions', [['show_forum', '=', 1], ['group_id', '=', auth()->user()->group_id]])
|
|
->when($this->search !== '', fn ($query) => $query->where('name', 'LIKE', '%'.$this->search.'%'))
|
|
->when($this->label !== '', fn ($query) => $query->where($this->label, '=', 1))
|
|
->when($this->state !== '', fn ($query) => $query->where('state', '=', $this->state))
|
|
->when(
|
|
$this->subscribed === 'include',
|
|
fn ($query) => $query
|
|
->whereRelation('subscribedUsers', 'users.id', '=', auth()->id())
|
|
)
|
|
->when(
|
|
$this->subscribed === 'exclude',
|
|
fn ($query) => $query
|
|
->whereDoesntHave('subscribedUsers', fn ($query) => $query->where('users.id', '=', auth()->id()))
|
|
)
|
|
->orderByDesc('pinned')
|
|
->orderBy($this->sortField, $this->sortDirection)
|
|
->paginate(25);
|
|
}
|
|
|
|
final public function render(): \Illuminate\Contracts\View\Factory|\Illuminate\Contracts\View\View|\Illuminate\Contracts\Foundation\Application
|
|
{
|
|
return view('livewire.forum-topic-search', [
|
|
'topics' => $this->topics,
|
|
]);
|
|
}
|
|
}
|