Files
UNIT3D-Community-Edition/app/Http/Livewire/NoteSearch.php
Roardom 72a1e1a885 refactor: rename warnings/bans/notes <-> user/staff relations
These relations are older than the laravel convention for using camel case. Clean up their names to match modern styling and make them easier to read.
2025-11-08 10:23:22 +00:00

69 lines
1.9 KiB
PHP

<?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\Note;
use Livewire\Attributes\Url;
use Livewire\Component;
use Livewire\WithPagination;
class NoteSearch extends Component
{
use WithPagination;
#TODO: Update URL attributes once Livewire 3 fixes upstream bug. See: https://github.com/livewire/livewire/discussions/7746
#[Url(history: true)]
public int $perPage = 25;
#[Url(history: true)]
public string $search = '';
final public function updatingSearch(): void
{
$this->resetPage();
}
/**
* @var \Illuminate\Pagination\LengthAwarePaginator<int, Note>
*/
final protected \Illuminate\Pagination\LengthAwarePaginator $notes {
get => Note::query()
->with([
'user' => fn ($query) => $query->withTrashed()->with(['group']),
'staff' => fn ($query) => $query->withTrashed()->with(['group']),
])
->when($this->search, fn ($query) => $query->where('message', 'LIKE', '%'.$this->search.'%'))
->latest()
->paginate($this->perPage);
}
final public function render(): \Illuminate\Contracts\View\Factory|\Illuminate\Contracts\View\View|\Illuminate\Contracts\Foundation\Application
{
return view('livewire.note-search', [
'notes' => $this->notes,
]);
}
final public function destroy(Note $note): void
{
$note->delete();
$this->dispatch('success', type: 'success', message: 'Note has successfully been deleted!');
}
}