Current File : /home/getxxhzo/app.genicards.com/app/Livewire/StateTable.php
<?php

namespace App\Livewire;

use App\Models\Country;
use App\Models\State;
use Illuminate\Database\Eloquent\Builder;
use Rappasoft\LaravelLivewireTables\Views\Column;
use Rappasoft\LaravelLivewireTables\DataTableComponent;


class StateTable extends LivewireTableComponent
{
    protected $model = State::class;

    public bool $showButtonOnHeader = true;

    public string $buttonComponent = 'sadmin.states.add-button';

    protected $listeners = ['refresh' => '$refresh', 'resetPageTable'];

    public function configure(): void
    {
        $this->setPrimaryKey('id');
        $this->setPageName('state-table');
        $this->setDefaultSort('created_at', 'desc');
        $this->setColumnSelectStatus(false);
        $this->setQueryStringStatus(false);
        $this->resetPage('state-table');

        $this->setThAttributes(function (Column $column) {
            if ($column->isField('id')) {
                return [
                    'class' => 'd-flex justify-content-center',
                ];
            }

            return [];
        });
    }

    public function columns(): array
    {
        return [
            Column::make(__('messages.state.state_name'), 'name')
                ->sortable()->searchable(),
            Column::make(__('messages.state.country_name'), 'country_id')
                ->sortable(function (Builder $query, $direction) {
                    return $query->orderBy(
                        Country::select('name')->whereColumn('id', 'country_id'),
                        $direction
                    );
                })->searchable()->view('sadmin/states/columns/country_name'),
            Column::make(__('messages.common.action'), 'id')
                ->view('sadmin/states/columns/action'),
        ];
    }

    public function builder(): Builder
    {
        return State::with('country')->select('states.*');
    }

    public function resetPageTable($pageName = 'state-table')
    {
        $rowsPropertyData = $this->getRows()->toArray();
        $prevPageNum = $rowsPropertyData['current_page'] - 1;
        $prevPageNum = $prevPageNum > 0 ? $prevPageNum : 1;
        $pageNum = count($rowsPropertyData['data']) > 0 ? $rowsPropertyData['current_page'] : $prevPageNum;

        $this->setPage($pageNum, $pageName);
    }
    public function placeholder()
    {
        return view('lazy_loading.without-filter-skelecton');
    }
}