first();
$invoice = InvoiceFactory::create($_project->company_id, $_project->user_id);
$invoice->client_id = $_project->client_id;
// $invoice->project_id = $project->id;
$lines = [];
foreach ($projects as $project) {
$project->tasks()
->withTrashed()
->whereNull('invoice_id')
->where('is_deleted', 0)
->cursor()
->each(function ($task, $key) use (&$lines) {
if (!$task->isRunning() && $task->calcDuration(true) > 0) {
if ($key == 0 && $task->company->invoice_task_project) {
$body = '
' .$task->project?->public_notes ?? ''; //@phpstan-ignore-line
$body .= ''.$task->description().'
';
} elseif (!$task->company->invoice_task_hours && !$task->company->invoice_task_timelog && !$task->company->invoice_task_datelog && !$task->company->invoice_task_item_description) {
$body = $task->description ?? '';
} else {
$body = ''.$task->description().'
';
}
$item = new InvoiceItem();
$item->quantity = $task->getQuantity();
$item->cost = $task->getRate();
$item->product_key = '';
$item->notes = $body;
$item->task_id = $task->hashed_id;
$item->tax_id = (string) Product::PRODUCT_TYPE_SERVICE;
$item->type_id = '2';
$item->custom_value1 = $task->custom_value1;
$item->custom_value2 = $task->custom_value2;
$item->custom_value3 = $task->custom_value3;
$item->custom_value4 = $task->custom_value4;
$lines[] = $item;
}
});
$project->expenses()
->withTrashed()
->where('should_be_invoiced', true)
->whereNull('payment_date')
->cursor()
->each(function ($expense) use (&$lines) {
$item = new InvoiceItem();
$item->quantity = 1;
$item->cost = $expense->foreign_amount > 0 ? $expense->foreign_amount : $expense->amount;
$item->product_key = $expense->category()->exists() ? $expense->category->name : '';
$item->notes = $expense->public_notes ?? '';
$item->line_total = round($item->cost * $item->quantity, 2);
$item->tax_name1 = $expense->tax_name1;
$item->tax_rate1 = $expense->calculatedTaxRate($expense->tax_amount1, $expense->tax_rate1);
$item->tax_name2 = $expense->tax_name2;
$item->tax_rate2 = $expense->calculatedTaxRate($expense->tax_amount2, $expense->tax_rate2);
$item->tax_name3 = $expense->tax_name3;
$item->tax_rate3 = $expense->calculatedTaxRate($expense->tax_amount3, $expense->tax_rate3);
$item->tax_id = (string) Product::PRODUCT_TYPE_PHYSICAL;
$item->expense_id = $expense->hashed_id;
$item->type_id = '1';
$item->custom_value1 = $expense->custom_value1;
$item->custom_value2 = $expense->custom_value2;
$item->custom_value3 = $expense->custom_value3;
$item->custom_value4 = $expense->custom_value4;
$lines[] = $item;
});
}
$invoice->uses_inclusive_taxes = $project->company->settings->inclusive_taxes ?? false;
$invoice->line_items = $lines;
return $invoice;
}
}