f0f9fdd555
Schema: - payments: client_id, work_order_id, user_id (operator), paid_at, amount, method (cash/card/transfer/mobile), reference, notes - expenses: supplier_id, purchase_id, paid_at, category (salary/purchase/rent/ utilities/advance/tax/fuel/tools/marketing/other), name, amount, method, ref Logică auto: - Payment::saved/deleted recalculează automat work_order.pay_status (unpaid → partial → paid) based on suma totală vs work_order.total - WO model are noi metode: payments(), paidAmount(), balanceDue() Filament resources (group Finanțe): - PaymentResource: form cu legare opțională la WO + client; tabel cu Sum summary, filtre azi/luna_curentă/method - ExpenseResource: 10 categorii preset, badge categ, total summary, filtru luna curentă - PaymentsRelationManager pe WO: "Plăți" tab cu auto-fill client_id + user_id la creare Widget FinanceOverview: - Încasări (luna), Cheltuieli (luna), Profit (luna), Datorii clienți - color coded: profit verde sau roșu, datorii galben/verde Settings page fix (Filament v5): - mount() folosește acum $this->form->fill([...]) în loc de $this->data direct - Filament v5 cere fill explicit pentru a inițializa state-ul schemei Seed: - 1 plată parțială pe fișa BMW (200 din 750) - 6 cheltuieli demo: 3 salarii, chirie, electricitate, achiziție piese Total Filament tenant routes: 69.
61 lines
2.3 KiB
PHP
61 lines
2.3 KiB
PHP
<?php
|
|
|
|
namespace App\Filament\Tenant\Resources\WorkOrderResource\RelationManagers;
|
|
|
|
use App\Models\Tenant\Payment;
|
|
use Filament\Actions;
|
|
use Filament\Forms;
|
|
use Filament\Resources\RelationManagers\RelationManager;
|
|
use Filament\Schemas\Schema;
|
|
use Filament\Tables;
|
|
use Filament\Tables\Table;
|
|
|
|
class PaymentsRelationManager extends RelationManager
|
|
{
|
|
protected static string $relationship = 'payments';
|
|
|
|
protected static ?string $title = 'Plăți';
|
|
|
|
public function form(Schema $schema): Schema
|
|
{
|
|
return $schema->components([
|
|
Forms\Components\DatePicker::make('paid_at')->label('Data')->default(today())->required(),
|
|
Forms\Components\TextInput::make('amount')->label('Sumă')->numeric()->required(),
|
|
Forms\Components\Select::make('method')
|
|
->options(Payment::METHODS)
|
|
->default('cash')
|
|
->required(),
|
|
Forms\Components\TextInput::make('reference')->label('Referință')->maxLength(64),
|
|
Forms\Components\Textarea::make('notes')->label('Notițe')->columnSpanFull()->rows(2),
|
|
]);
|
|
}
|
|
|
|
public function table(Table $table): Table
|
|
{
|
|
return $table
|
|
->recordTitleAttribute('amount')
|
|
->columns([
|
|
Tables\Columns\TextColumn::make('paid_at')->label('Data')->date('d.m.Y'),
|
|
Tables\Columns\TextColumn::make('amount')->money('MDL')->alignRight()
|
|
->summarize(Tables\Columns\Summarizers\Sum::make()->money('MDL')->label('Plătit')),
|
|
Tables\Columns\TextColumn::make('method')
|
|
->formatStateUsing(fn ($s) => Payment::METHODS[$s] ?? $s)
|
|
->badge(),
|
|
Tables\Columns\TextColumn::make('reference')->placeholder('—'),
|
|
])
|
|
->headerActions([
|
|
Actions\CreateAction::make()->mutateFormDataUsing(function (array $data, RelationManager $livewire): array {
|
|
$wo = $livewire->getOwnerRecord();
|
|
$data['client_id'] = $wo->client_id;
|
|
$data['user_id'] = auth()->id();
|
|
return $data;
|
|
}),
|
|
])
|
|
->actions([
|
|
Actions\EditAction::make(),
|
|
Actions\DeleteAction::make(),
|
|
])
|
|
->defaultSort('paid_at', 'desc');
|
|
}
|
|
}
|