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,
- ]);
- });
- }
- }
|