You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <?php
  2. namespace Database\Seeders;
  3. use App\Models\Setting\Tax;
  4. use Illuminate\Database\Seeder;
  5. use Illuminate\Support\Facades\DB;
  6. class TaxSeeder extends Seeder
  7. {
  8. /**
  9. * Run the database seeds.
  10. */
  11. public function run(): void
  12. {
  13. $companyId = DB::table('companies')->first()->id;
  14. $userId = DB::table('users')->first()->id;
  15. $salesTaxes = [
  16. 'Goods and Services Tax (GST)',
  17. 'Value Added Tax (VAT)',
  18. 'State Sales Tax',
  19. 'Local Sales Tax',
  20. 'Excise Tax',
  21. ];
  22. $purchaseTaxes = [
  23. 'Import Duty',
  24. 'Customs Duty',
  25. 'Value Added Tax (VAT)',
  26. 'Luxury Tax',
  27. 'Environmental Tax',
  28. ];
  29. $shuffledTaxes = [
  30. ...array_map(static fn($name) => ['name' => $name, 'type' => 'sales'], $salesTaxes),
  31. ...array_map(static fn($name) => ['name' => $name, 'type' => 'purchase'], $purchaseTaxes)
  32. ];
  33. shuffle($shuffledTaxes);
  34. $allTaxes = $shuffledTaxes;
  35. foreach ($allTaxes as $tax) {
  36. Tax::factory()->create([
  37. 'company_id' => $companyId,
  38. 'name' => $tax['name'],
  39. 'type' => $tax['type'],
  40. 'enabled' => false,
  41. 'created_by' => $userId,
  42. 'updated_by' => $userId,
  43. ]);
  44. }
  45. Tax::where('type', 'sales')
  46. ->where('company_id', $companyId)
  47. ->first()
  48. ->update(['enabled' => true]);
  49. Tax::where('type', 'purchase')
  50. ->where('company_id', $companyId)
  51. ->first()
  52. ->update(['enabled' => true]);
  53. }
  54. }