2020-04-01 23:35:06 +11:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Console\Commands;
|
|
|
|
|
2024-08-03 10:06:25 +10:00
|
|
|
use Carbon\Carbon;
|
2020-04-01 23:35:06 +11:00
|
|
|
use Illuminate\Console\Command;
|
2022-03-05 11:05:35 +11:00
|
|
|
use Illuminate\Support\Facades\Config;
|
|
|
|
|
2022-08-25 11:08:10 +10:00
|
|
|
use App\Models\{Account,Invoice,Site};
|
2020-04-01 23:35:06 +11:00
|
|
|
|
|
|
|
class InvoiceGenerate extends Command
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The name and signature of the console command.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2024-08-03 10:06:25 +10:00
|
|
|
protected $signature = 'invoice:generate'
|
|
|
|
.' {--l|list : List Items}'
|
|
|
|
.' {--p|preview : Preview}'
|
|
|
|
.' {--s|site : Site ID}'
|
|
|
|
.' {id?}';
|
2020-04-01 23:35:06 +11:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The console command description.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $description = 'Generate Invoices to be Sent';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the console command.
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function handle()
|
|
|
|
{
|
2024-08-03 10:06:25 +10:00
|
|
|
Config::set(
|
|
|
|
'site',
|
|
|
|
$this->option('site')
|
|
|
|
? Site::findOrFail($this->option('site'))
|
|
|
|
: Site::where('url',config('app.url'))->sole()
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($this->argument('id'))
|
|
|
|
$accounts = collect()->push(Account::find($this->argument('id')));
|
2020-04-01 23:35:06 +11:00
|
|
|
else
|
|
|
|
$accounts = Account::active()->get();
|
|
|
|
|
|
|
|
foreach ($accounts as $o) {
|
2024-08-03 10:06:25 +10:00
|
|
|
$items = $o->invoice_next(Carbon::now());
|
|
|
|
|
|
|
|
if (! $items->count()) {
|
|
|
|
$this->warn(sprintf('No items for account (%s) [%d]',$o->name,$o->id));
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->info(sprintf('Account: %s [%d]',$o->name,$o->lid));
|
2020-04-01 23:35:06 +11:00
|
|
|
$io = new Invoice;
|
2020-05-29 14:10:10 +10:00
|
|
|
$io->account_id = $o->id;
|
2020-04-01 23:35:06 +11:00
|
|
|
|
2024-08-03 10:06:25 +10:00
|
|
|
foreach ($items as $oo)
|
|
|
|
$io->items_active->push($oo);
|
2020-04-01 23:35:06 +11:00
|
|
|
|
|
|
|
// If there are no items, no reason to do anything
|
2024-08-03 10:06:25 +10:00
|
|
|
if ($io->total < 0) {
|
|
|
|
$this->warn(sprintf(' - Invoice totals [%3.2f] - skipping',$io->total));
|
2020-04-01 23:35:06 +11:00
|
|
|
continue;
|
2024-08-03 10:06:25 +10:00
|
|
|
}
|
2020-04-01 23:35:06 +11:00
|
|
|
|
|
|
|
$io->account_id = $o->id;
|
|
|
|
|
2020-05-29 14:40:49 +10:00
|
|
|
if ($this->option('list')) {
|
2024-08-03 10:06:25 +10:00
|
|
|
$this->line(sprintf('|%4s|%4s|%-50s|%8s|',
|
2020-05-29 14:40:49 +10:00
|
|
|
'SID',
|
|
|
|
'PID',
|
|
|
|
'Name',
|
|
|
|
'Amount',
|
|
|
|
));
|
|
|
|
|
2024-08-03 10:06:25 +10:00
|
|
|
foreach ($io->items_active as $oo) {
|
2020-05-29 14:40:49 +10:00
|
|
|
$this->info(sprintf('|%4s|%4s|%-50s|%8.2f|',
|
|
|
|
$oo->service_id,
|
|
|
|
$oo->product_id,
|
|
|
|
$oo->item_type_name,
|
|
|
|
$oo->total,
|
2020-06-02 17:19:24 +10:00
|
|
|
));
|
2020-05-29 14:40:49 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-08-03 10:06:25 +10:00
|
|
|
//dump($io);
|
2020-04-01 23:35:06 +11:00
|
|
|
if ($this->option('preview')) {
|
2024-08-03 10:06:25 +10:00
|
|
|
$this->info(sprintf('=> Invoice for Account [%d] - [%d] items totalling [%3.2f]',$o->id,$io->items_active->count(),$io->total));
|
2020-04-01 23:35:06 +11:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Save the invoice
|
|
|
|
$io->site_id = 1; // @todo
|
|
|
|
$io->active = 1;
|
|
|
|
|
|
|
|
$io->pushNew();
|
|
|
|
}
|
2024-08-03 10:06:25 +10:00
|
|
|
|
|
|
|
return self::SUCCESS;
|
2020-04-01 23:35:06 +11:00
|
|
|
}
|
|
|
|
}
|