| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 | <?php
namespace Database\Factories\Accounting;
use App\Models\Accounting\Bill;
use App\Models\Accounting\DocumentLineItem;
use App\Models\Accounting\Estimate;
use App\Models\Accounting\Invoice;
use App\Models\Accounting\RecurringInvoice;
use App\Models\Common\Offering;
use Illuminate\Database\Eloquent\Factories\Factory;
/**
 * @extends Factory<DocumentLineItem>
 */
class DocumentLineItemFactory extends Factory
{
    /**
     * The name of the factory's corresponding model.
     */
    protected $model = DocumentLineItem::class;
    /**
     * Define the model's default state.
     *
     * @return array<string, mixed>
     */
    public function definition(): array
    {
        $quantity = $this->faker->numberBetween(1, 10);
        return [
            'company_id' => 1,
            'description' => $this->faker->sentence,
            'quantity' => $quantity,
            'created_by' => 1,
            'updated_by' => 1,
        ];
    }
    public function forInvoice(Invoice | RecurringInvoice $invoice): static
    {
        return $this
            ->for($invoice, 'documentable')
            ->for($invoice->company, 'company')
            ->afterCreating(function (DocumentLineItem $lineItem) {
                $offering = Offering::query()
                    ->where('company_id', $lineItem->company_id)
                    ->where('sellable', true)
                    ->inRandomOrder()
                    ->firstOrFail();
                $lineItem->updateQuietly([
                    'offering_id' => $offering->id,
                    'unit_price' => $offering->price,
                ]);
                $lineItem->salesTaxes()->syncWithoutDetaching($offering->salesTaxes->pluck('id')->toArray());
                $lineItem->salesDiscounts()->syncWithoutDetaching($offering->salesDiscounts->pluck('id')->toArray());
                $lineItem->refresh();
                $taxTotal = $lineItem->calculateTaxTotal()->getAmount();
                $discountTotal = $lineItem->calculateDiscountTotal()->getAmount();
                $lineItem->updateQuietly([
                    'tax_total' => $taxTotal,
                    'discount_total' => $discountTotal,
                ]);
            });
    }
    public function forEstimate(Estimate $estimate): static
    {
        return $this
            ->for($estimate, 'documentable')
            ->for($estimate->company, 'company')
            ->afterCreating(function (DocumentLineItem $lineItem) {
                $offering = Offering::query()
                    ->where('company_id', $lineItem->company_id)
                    ->where('sellable', true)
                    ->inRandomOrder()
                    ->firstOrFail();
                $lineItem->updateQuietly([
                    'offering_id' => $offering->id,
                    'unit_price' => $offering->price,
                ]);
                $lineItem->salesTaxes()->syncWithoutDetaching($offering->salesTaxes->pluck('id')->toArray());
                $lineItem->salesDiscounts()->syncWithoutDetaching($offering->salesDiscounts->pluck('id')->toArray());
                $lineItem->refresh();
                $taxTotal = $lineItem->calculateTaxTotal()->getAmount();
                $discountTotal = $lineItem->calculateDiscountTotal()->getAmount();
                $lineItem->updateQuietly([
                    'tax_total' => $taxTotal,
                    'discount_total' => $discountTotal,
                ]);
            });
    }
    public function forBill(Bill $bill): static
    {
        return $this
            ->for($bill, 'documentable')
            ->for($bill->company, 'company')
            ->afterCreating(function (DocumentLineItem $lineItem) {
                $offering = Offering::query()
                    ->where('company_id', $lineItem->company_id)
                    ->where('purchasable', true)
                    ->inRandomOrder()
                    ->firstOrFail();
                $lineItem->updateQuietly([
                    'offering_id' => $offering->id,
                    'unit_price' => $offering->price,
                ]);
                $lineItem->purchaseTaxes()->syncWithoutDetaching($offering->purchaseTaxes->pluck('id')->toArray());
                $lineItem->purchaseDiscounts()->syncWithoutDetaching($offering->purchaseDiscounts->pluck('id')->toArray());
                $lineItem->refresh();
                $taxTotal = $lineItem->calculateTaxTotal()->getAmount();
                $discountTotal = $lineItem->calculateDiscountTotal()->getAmount();
                $lineItem->updateQuietly([
                    'tax_total' => $taxTotal,
                    'discount_total' => $discountTotal,
                ]);
            });
    }
}
 |