[Update] Data seeder

This commit is contained in:
Baghaztra 2025-09-15 14:42:03 +07:00
parent f252e53fc3
commit 6adc5c0f98
2 changed files with 50 additions and 21 deletions

View File

@ -2,6 +2,7 @@
namespace Database\Factories; namespace Database\Factories;
use App\Models\Produk;
use Illuminate\Database\Eloquent\Factories\Factory; use Illuminate\Database\Eloquent\Factories\Factory;
/** /**
@ -17,7 +18,7 @@ class ItemFactory extends Factory
public function definition(): array public function definition(): array
{ {
return [ return [
'id_produk' => \App\Models\Produk::factory(), 'id_produk' => Produk::inRandomOrder()->first()->id,
'id_nampan' => null, 'id_nampan' => null,
]; ];
} }

View File

@ -49,31 +49,59 @@ class DatabaseSeeder extends Seeder
]); ]);
} }
Produk::factory(10)->create()->each(function ($produk) { // Produk::factory(10)->create()->each(function ($produk) {
// setiap produk punya 1-3 foto // // setiap produk punya 1-3 foto
$jumlah_foto = rand(1, 3); // $jumlah_foto = rand(1, 3);
$fotoData = []; // $fotoData = [];
for ($i = 0; $i < $jumlah_foto; $i++) { // for ($i = 0; $i < $jumlah_foto; $i++) {
$fotoData[] = [ // $fotoData[] = [
// 'url' => 'https://random-image-pepebigotes.vercel.app/api/random-image' // // 'url' => 'https://random-image-pepebigotes.vercel.app/api/random-image'
'url' => 'https://static.promediateknologi.id/crop/0x0:0x0/0x0/webp/photo/p2/255/2024/12/10/Screenshot_2024-12-10-11-50-18-88_1c337646f29875672b5a61192b9010f9-1-1282380831.jpg' // 'url' => 'https://static.promediateknologi.id/crop/0x0:0x0/0x0/webp/photo/p2/255/2024/12/10/Screenshot_2024-12-10-11-50-18-88_1c337646f29875672b5a61192b9010f9-1-1282380831.jpg'
]; // ];
} // }
$produk->foto()->createMany($fotoData); // $produk->foto()->createMany($fotoData);
$jumlah_item = rand(1, 20); // $jumlah_item = rand(1, 20);
Item::factory($jumlah_item)->create([ // Item::factory($jumlah_item)->create([
'id_produk' => $produk->id, // 'id_produk' => $produk->id,
// ]);
// });
$produk1 = Produk::factory()->create([
'nama'=>'Gelang serut daun shimmer mp (mas putih)',
'id_kategori'=>Kategori::find(2),
'berat'=>1.4,
'kadar'=>8,
'harga_per_gram'=>900000,
'harga_jual'=>1260000,
]);
$produk1->foto()->create([
'id_produk'=>$produk1->id,
'url'=>'https://i.imgur.com/eGYHzvw.jpeg'
]); ]);
});
// 30% peluang item masuk nampan, sisanya di brankas $produk2 = Produk::factory()->create([
'nama'=>'Gelang rantai 5 buah clover merah',
'id_kategori'=>Kategori::find(2),
'berat'=>3.6,
'kadar'=>8,
'harga_per_gram'=>850000,
'harga_jual'=>3060000,
]);
$produk2->foto()->create([
'id_produk'=>$produk2->id,
'url'=>'https://i.imgur.com/UjQzYoE.jpeg'
]);
Item::factory(500)->create();
// 75% peluang item masuk nampan, sisanya di brankas
$nampans = Nampan::all()->pluck('id')->toArray(); $nampans = Nampan::all()->pluck('id')->toArray();
$jumlahNampan = count($nampans); $jumlahNampan = count($nampans);
$counter = 0; $counter = 0;
foreach (Item::all() as $item) { foreach (Item::all() as $item) {
if (rand(1, 100) <= 30) { if (rand(1, 100) <= 75) {
$item->update([ $item->update([
'id_nampan' => $nampans[$counter % $jumlahNampan], 'id_nampan' => $nampans[$counter % $jumlahNampan],
]); ]);
@ -81,7 +109,7 @@ class DatabaseSeeder extends Seeder
} }
} }
Transaksi::factory(40)->create()->each(function ($transaksi) { Transaksi::factory(250)->create()->each(function ($transaksi) {
$jumlah_item = rand(1, 2); $jumlah_item = rand(1, 2);
$items = Item::with('produk')->inRandomOrder()->limit($jumlah_item)->get(); $items = Item::with('produk')->inRandomOrder()->limit($jumlah_item)->get();
if ($items->isEmpty()) return; if ($items->isEmpty()) return;
@ -90,7 +118,7 @@ class DatabaseSeeder extends Seeder
$transaksi->itemTransaksi()->create([ $transaksi->itemTransaksi()->create([
'id_produk' => $item->produk->id, 'id_produk' => $item->produk->id,
'harga_deal' => $item->produk->harga_jual, 'harga_deal' => $item->produk->harga_jual,
'posisi_asal' => $item->id_nampan ? 'Nampan ' . $item->nampan->nama : 'Brankas', 'posisi_asal' => $item->id_nampan ? $item->nampan->nama : 'Brankas',
]); ]);
$item->delete(); $item->delete();
$total_harga += $item->produk->harga_jual; $total_harga += $item->produk->harga_jual;