سلام شب بخیر من اطلاعات استان و شهر و منطقه رو موقع ثبت نام از کاربر میخام که از طریق ایجکس اطلاعات رو از دیتابیس دریافت میکنم که تا اینجا اکیه
حالا میخام تو پنل مدیریت بتونم مناطق شهرهارو غیرفعال یا فعال کنم مثلا اگه شهر تهران انتخاب شد بتونم تمام مناطقش رو فعال و غیرفعال کنم
برای این چون با ایجکس هست به مشکل خوردم و نتو نستم انجام بدم
الان تمام منطقه هارو نمایش میده چجوری دکمه فعال و غیرفعال رو بزارم که تمام مناطق یک شهر رو در بر بگیره
دیتابیس منطقه
Schema::create('regions', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->tinyInteger('status')->default(1);
$table->foreignId('city_id')->constrained()->cascadeOnDelete();
$table->timestamps();
});
روت
Route::get('/locations' , [AdminController::class , 'showLocation'])->name('locations');
Route::post('/locations/fetch-cities' , [AdminController::class , 'fetchCity']);
Route::post('/locations/fetch-regions' , [AdminController::class , 'fetchRegion']);
Route::post('/locations' , [AdminController::class , 'submitLocation'])->name('send.locations');
Route::get('locations/status/{location}', [AdminController::class ,'updatestatus'])->name('location.status');
کنترلر
public function showLocation()
{
$provinces = $data['province'] = Province::get(["name", "id"]);
// $regions = Region::get();
return view('admin.locations.location' , compact('provinces'));
}
public function fetchCity(Request $request)
{
$data['cities'] = City::where("province_id", $request->province_id)
->get(["name", "id"]);
return response()->json($data);
}
public function fetchRegion(Request $request)
{
$data['regions'] = Region::where("city_id", $request->city_id)
->get(["name", "id"]);
return response()->json($data);
}
public function submitLocation(Request $request , Region $region)
{
$request->validate([
'province' => 'required',
'city' => 'required',
'region' => 'required',
]);
if (Region::where('city_id', $request->city)->count() > 0)
{
if ($request->region[0] == 'status') {
$region = Region::where('city_id', $request->city)->get();
} else {
alert("لطفا یک گزینه را انتخاب کنید");
}
} else {
return redirect(route('locations'));
}
return redirect(route('locations'));
}
public function updatestatus(Region $region)
{
if ($region->status == 1) {
$region->status = 0;
} else {
$region->status = 1;
}
$region->save();
alert()->success('به روز رسانی با موفقیت انجام شد' , 'با تشکر');
return redirect(route('regions'));
}
ایجکس
$(document).ready(function () {
$('#province-dropdown').on('change', function () {
var idProvince = this.value;
$("#city-dropdown").html('');
$.ajax({
url: "{{url('admin/locations/fetch-cities')}}",
type: "POST",
data: {
province_id: idProvince,
_token: '{{csrf_token()}}'
},
dataType: 'json',
success: function (result) {
$('#city-dropdown').html('<option value=""> انتخاب شهر </option>');
$.each(result.cities, function (key, value) {
$("#city-dropdown").append('<option value="' + value
.id + '">' + value.name + '</option>');
});
$('#region-dropdown').html('<option value="">انتخاب منطقه</option>');
}
});
});
$('#city-dropdown').on('change', function () {
var idCity = this.value;
$("#region-dropdown").html('');
$.ajax({
url: "{{url('admin/locations/fetch-regions')}}",
type: "POST",
data: {
city_id: idCity,
_token: '{{csrf_token()}}'
},
dataType: 'json',
success: function (res) {
$('#region-dropdown').html('<option value="status">غیرفعال</option>');
$.each(res.regions, function (key, value) {
$("#region-dropdown").append('<option value="' + value
.id + '">' + value.name + '</option>');
});
}
});
});
});
به Paradox کمک کنید تا مشکل خودش را حل کند؛ اینطور میتوانیم با هم پیشرفت کنیم.
آیا مایل به ارسال نوتیفیکیشن و اخبار از طرف راکت هستید ؟