mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-07 21:44:51 +00:00
* feat: Tax included * Added a toggle switch in tax settings to enable the feature. * Database migration adding tax_included field into estimates, invoices and recurring invoices table. * Toggle switch to enable and store the tax_included by estimates, invoices and recurring invoices. * In case of tax included enabled, total taxes will be recalculated and the invoices, estimates and recurring invoices total won't be sum with taxes. * Apply tax included when discount_per_item/tax_per_item item is enabled. * Custom component to show the net total when tax included is enabled. * Update invoice and estimates pdfs with net total. * chore: Tax included by default A switch button inside the tax settings to enable the tax included by default in invoices, estimates and recurring invoices.
47 lines
1.6 KiB
PHP
47 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace Database\Factories;
|
|
|
|
use App\Models\Customer;
|
|
use App\Models\RecurringInvoice;
|
|
use App\Models\User;
|
|
use Illuminate\Database\Eloquent\Factories\Factory;
|
|
|
|
class RecurringInvoiceFactory extends Factory
|
|
{
|
|
/**
|
|
* The name of the factory's corresponding model.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $model = RecurringInvoice::class;
|
|
|
|
/**
|
|
* Define the model's default state.
|
|
*/
|
|
public function definition(): array
|
|
{
|
|
return [
|
|
'starts_at' => $this->faker->iso8601(),
|
|
'send_automatically' => false,
|
|
'status' => $this->faker->randomElement(['COMPLETED', 'ON_HOLD', 'ACTIVE']),
|
|
'tax_per_item' => 'NO',
|
|
'tax_included' => false,
|
|
'discount_per_item' => 'NO',
|
|
'sub_total' => $this->faker->randomDigitNotNull(),
|
|
'total' => $this->faker->randomDigitNotNull(),
|
|
'tax' => $this->faker->randomDigitNotNull(),
|
|
'due_amount' => $this->faker->randomDigitNotNull(),
|
|
'discount' => $this->faker->randomDigitNotNull(),
|
|
'discount_val' => $this->faker->randomDigitNotNull(),
|
|
'customer_id' => Customer::factory(),
|
|
'company_id' => User::find(1)->companies()->first()->id,
|
|
'frequency' => '* * 18 * *',
|
|
'limit_by' => $this->faker->randomElement(['NONE', 'COUNT', 'DATE']),
|
|
'limit_count' => $this->faker->randomDigit(),
|
|
'limit_date' => $this->faker->date(),
|
|
'exchange_rate' => $this->faker->randomDigitNotNull(),
|
|
];
|
|
}
|
|
}
|