[Update] Data seeder
This commit is contained in:
parent
f252e53fc3
commit
6adc5c0f98
@ -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,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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,
|
||||||
]);
|
// ]);
|
||||||
});
|
// });
|
||||||
|
|
||||||
// 30% peluang item masuk nampan, sisanya di brankas
|
$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'
|
||||||
|
]);
|
||||||
|
|
||||||
|
$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;
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user