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

170 lines
6.2 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Models\CustomerLevel;
use App\Models\LocationProfile;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
class LocationProfileController extends Controller
{
public function index(Request $request)
{
$query = LocationProfile::with(['location'])->orderBy('updated_at', 'desc');
if ($request->location_id != '') {
$query->where('location_id', $request->location_id);
}
if ($request->q != '') {
$query->where('name', 'like', "%$request->q%")
->orWhere('display_note', 'like', "%$request->q%");
}
return inertia('LocationProfile/Index', [
'query' => $query->paginate(),
]);
}
public function create()
{
return inertia('LocationProfile/Form', [
'expireds' => LocationProfile::EXPIRED_UNIT,
'levels' => CustomerLevel::all(),
]);
}
public function store(Request $request)
{
$request->validate([
'location_id' => 'required|exists:locations,id',
'name' => 'required|string',
'quota' => 'required|string',
'display_note' => 'nullable|string',
'expired' => 'required|numeric',
'expired_unit' => 'required|string',
'description' => 'nullable|string',
'min_stock' => 'required|numeric',
'display_price' => 'required|numeric',
'discount' => 'required|numeric|min:0|max:100',
'price_poin' => 'required|numeric',
'bonus_poin' => 'required|numeric',
'prices' => 'nullable|array',
'prices.*.customer_level_id' => 'required|exists:customer_levels,id',
'prices.*.display_price' => 'required|numeric',
'prices.*.discount' => 'required|numeric|min:0|max:100',
'prices.*.price_poin' => 'required|numeric',
'prices.*.bonus_poin' => 'required|numeric',
]);
DB::beginTransaction();
$profile = LocationProfile::create([
'location_id' => $request->location_id,
'name' => $request->name,
'quota' => $request->quota,
'display_note' => $request->display_note,
'expired' => $request->expired,
'expired_unit' => $request->expired_unit,
'description' => $request->description,
'min_stock' => $request->min_stock,
'display_price' => $request->display_price,
'discount' => $request->discount,
'price_poin' => $request->price_poin,
'bonus_poin' => $request->bonus_poin,
]);
$prices = collect($request->prices);
if ($prices->count() > 0) {
foreach ($prices as $price) {
$profile->prices()->create([
'customer_level_id' => $price['customer_level_id'],
'display_price' => $price['display_price'],
'discount' => $price['discount'],
'price_poin' => $price['price_poin'],
'bonus_poin' => $price['bonus_poin'],
]);
}
}
DB::commit();
return redirect()->route('location-profile.index')
->with('message', ['type' => 'success', 'message' => 'Item has beed saved']);
}
public function edit(LocationProfile $profile)
{
return inertia('LocationProfile/Form', [
'expireds' => LocationProfile::EXPIRED_UNIT,
'levels' => CustomerLevel::all(),
'profile' => $profile->load(['location', 'prices.level'])
]);
}
public function update(Request $request, LocationProfile $profile)
{
$request->validate([
'location_id' => 'required|exists:locations,id',
'name' => 'required|string',
'quota' => 'required|string',
'display_note' => 'nullable|string',
'expired' => 'required|numeric',
'expired_unit' => 'required|string',
'description' => 'nullable|string',
'min_stock' => 'required|numeric',
'display_price' => 'required|numeric',
'discount' => 'required|numeric|min:0|max:100',
'price_poin' => 'required|numeric',
'bonus_poin' => 'required|numeric',
'prices' => 'nullable|array',
'prices.*.customer_level_id' => 'required|exists:customer_levels,id',
'prices.*.display_price' => 'required|numeric',
'prices.*.discount' => 'required|numeric|min:0|max:100',
'prices.*.price_poin' => 'required|numeric',
'prices.*.bonus_poin' => 'required|numeric',
]);
DB::beginTransaction();
$profile->update([
'location_id' => $request->location_id,
'name' => $request->name,
'quota' => $request->quota,
'display_note' => $request->display_note,
'expired' => $request->expired,
'expired_unit' => $request->expired_unit,
'description' => $request->description,
'min_stock' => $request->min_stock,
'display_price' => $request->display_price,
'discount' => $request->discount,
'price_poin' => $request->price_poin,
'bonus_poin' => $request->bonus_poin,
]);
$profile->prices()->delete();
$prices = collect($request->prices);
if ($prices->count() > 0) {
foreach ($prices as $price) {
$profile->prices()->create([
'customer_level_id' => $price['customer_level_id'],
'display_price' => $price['display_price'],
'discount' => $price['discount'],
'price_poin' => $price['price_poin'],
'bonus_poin' => $price['bonus_poin'],
]);
}
}
DB::commit();
return redirect()->route('location-profile.index')
->with('message', ['type' => 'success', 'message' => 'Item has beed updated']);
}
public function destroy(LocationProfile $profile)
{
$profile->delete();
return redirect()->route('location-profile.index')
->with('message', ['type' => 'success', 'message' => 'Item has beed deleted']);
}
}