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->name.'
' .$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; } }