Add sample data seeder
This commit is contained in:
parent
d66422dfde
commit
1f0dd178dc
47
app/Console/Commands/SampleData.php
Executable file
47
app/Console/Commands/SampleData.php
Executable file
@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Console\Commands;
|
||||||
|
|
||||||
|
use Database\Seeds\SampleData as SampleDataSeeder;
|
||||||
|
use Illuminate\Console\Command;
|
||||||
|
|
||||||
|
class SampleData extends Command
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* The name and signature of the console command.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $signature = 'sample-data:seed {--count=100 : total records for each item}';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The console command description.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $description = 'Seed for sample data';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new command instance.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Execute the console command.
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$class = $this->laravel->make(SampleDataSeeder::class);
|
||||||
|
|
||||||
|
$seeder = $class->setContainer($this->laravel)->setCommand($this);
|
||||||
|
|
||||||
|
$seeder->__invoke();
|
||||||
|
}
|
||||||
|
}
|
109
database/seeds/SampleData.php
Executable file
109
database/seeds/SampleData.php
Executable file
@ -0,0 +1,109 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Database\Seeds;
|
||||||
|
|
||||||
|
use App\Abstracts\Model;
|
||||||
|
use App\Jobs\Banking\CreateAccount;
|
||||||
|
use App\Jobs\Banking\CreateDocumentTransaction;
|
||||||
|
use App\Jobs\Common\CreateContact;
|
||||||
|
use App\Jobs\Common\CreateItem;
|
||||||
|
use App\Jobs\Purchase\CreateBill;
|
||||||
|
use App\Jobs\Sale\CreateInvoice;
|
||||||
|
use App\Models\Banking\Account;
|
||||||
|
use App\Models\Banking\Transaction;
|
||||||
|
use App\Models\Common\Contact;
|
||||||
|
use App\Models\Common\Item;
|
||||||
|
use App\Models\Purchase\Bill;
|
||||||
|
use App\Models\Sale\Invoice;
|
||||||
|
use App\Traits\Jobs;
|
||||||
|
use Faker\Factory;
|
||||||
|
use Illuminate\Database\Seeder;
|
||||||
|
|
||||||
|
class SampleData extends Seeder
|
||||||
|
{
|
||||||
|
use Jobs;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run the database seeds.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function run()
|
||||||
|
{
|
||||||
|
Model::reguard();
|
||||||
|
|
||||||
|
$faker = Factory::create();
|
||||||
|
|
||||||
|
$count = $this->command->option('count');
|
||||||
|
|
||||||
|
for ($i = 0; $i < $count; $i++) {
|
||||||
|
$this->dispatch(new CreateContact(factory(Contact::class)->raw()));
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < $count; $i++) {
|
||||||
|
$this->dispatch(new CreateItem(factory(Item::class)->raw()));
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < $count; $i++) {
|
||||||
|
$this->dispatch(new CreateAccount(factory(Account::class)->raw()));
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < $count; $i++) {
|
||||||
|
$this->dispatch(new CreateBill(factory(Bill::class)->state('items')->raw()));
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < $count; $i++) {
|
||||||
|
$this->dispatch(new CreateInvoice(factory(Invoice::class)->state('items')->raw()));
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < $count; $i++) {
|
||||||
|
$amount = $faker->randomFloat(2, 1, 1000);
|
||||||
|
$invoices = Invoice::where('status', 'sent')->get();
|
||||||
|
|
||||||
|
if (0 === $invoices->count()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$invoice = $invoices->random(1)->first();
|
||||||
|
|
||||||
|
$this->dispatch(
|
||||||
|
new CreateDocumentTransaction(
|
||||||
|
$invoice,
|
||||||
|
factory(Transaction::class)->state('income')->raw(
|
||||||
|
[
|
||||||
|
'contact_id' => $invoice->contact_id,
|
||||||
|
'document_id' => $invoice->id,
|
||||||
|
'amount' => $amount > $invoice->amount ? $invoice->amount : $amount,
|
||||||
|
]
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < $count; $i++) {
|
||||||
|
$amount = $faker->randomFloat(2, 1, 1000);
|
||||||
|
$bills = Bill::where('status', 'received')->get();
|
||||||
|
|
||||||
|
if (0 === $bills->count()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$bill = $bills->random(1)->first();
|
||||||
|
|
||||||
|
$this->dispatch(
|
||||||
|
new CreateDocumentTransaction(
|
||||||
|
$bill,
|
||||||
|
factory(Transaction::class)->state('expense')->raw(
|
||||||
|
[
|
||||||
|
'contact_id' => $bill->contact_id,
|
||||||
|
'document_id' => $bill->id,
|
||||||
|
'amount' => $amount > $bill->amount ? $bill->amount : $amount,
|
||||||
|
]
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
Model::unguard();
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user