سلام دوستان.
من یک سایت دارم که هر کاربر میتونه املاکی که قرار به فروش برسونه رو ثبت کنه و کاربران دیگر میتونن اون املاک رو سفارش بدن.
داخل پنل هر کاربر هم یه قسمت به نام سفارشات شما هست که هر کاربر میتونه املاکی که سفارش داده رو مشاهده کنه و یه قسمت هم به نام پیشنهادات مشتریان هست که کاربر میتونه ببینه که چه شخصی قصد داره کدوم ملکش رو خریداری کنه.
حالا سوالی که هست اینه که وقتی میخوام یک سطر رو از قسمت سفارشات شما حذف کنم از کد زیر استفاده میکنم که درست هم کار میکنه.
public function destroy(int $index)
{
$order = Order::where('id', $index)->first();
$order->delete();
return redirect()->back();
}
حالا اگر بخوام عمل حذف رو از قسمت پیشنهادات مشتریان انجام بدم باید چیکار کنم؟
دستوری که در کنترلر نوشتم به این صورت هست که اطلاعات هم به درستی نمایش میده ولی حذف نمیدونم باید چیکار کنم!؟
$offers = Order::select('user_id')->where('estate_id', auth()->user()->id)->get();
سلام.
اول: در حین دیباگکردن، هلپر dd بهترین دوست شماست و میتونستید متغیر offers$ رو باهاش چک کنید.
دوم: شرط شما ایراد داره، چون گفتید که اگه estate_id برابر id کاربر فعلی بود، مگه estate_id همون id ملک نیست؟!
سوم: چرا از select استفاده کردید؟ شما که user_id رو دارید و نیازی بهش نیست!
چهارم: شما با get یک collection خواهید داشت، پس نباید delete رو روی اون صدا بزنید. شما اگه به جای get بنویسید delete درست میشه.
پنجم: اگه جای دیگهای قراره از id این املاک (نه یوزرها) استفاده کنید، اینطوری انجامش بدید:
$offers = Order::where('user_id', auth()->user()->id)->pluck('id');
// Do what you want here
Order::destroy($offers);
زندگیتون بیباگ 😏
@muhammad
ببینید دوست عزیز فرض کنید کاربر شماره 1 اومده یه ملک ثبت کرده و کاربر شماره 2 اومده ملک کاربر شماره 1 رو سفارش داده، الان قسمت پیشنهادات مشتریان کاربر شماره 1، مشخصات کاربر شماره 2 و مشخصات اون ملکی که کاربر شماره 2 سفارش داده رو میشه مشاهده کرد با استفاده از دستور زیر که به درستی هم کار میکنه.
$offers = Order::select('user_id')->where('estate_id', auth()->user()->id)->get();
مشکل من اینجاست که قسمت پیشنهادات مشتریان یک دگمه حذف گذاشتم الان مشکل اینجاست که هر کاربر چطور بتونه پیشنهادات مشتریان رو حذف کنه؟
در واقع فانکشن destroy رو چطور بنویسم؟
از اینکه کد کار میکنه متعجبم، اما متد destroy: این متد رو روی مدل صدا زده میشه و میتونید بهش آرایهای از idهای اون جدول رو بدید.
همچنین اگه به جای get روی همین کوئری خودتون (در صورتی که واقعا کار کنه) delete بزنید، رکوردهارو حذف میکنه.
آیا مایل به ارسال نوتیفیکیشن و اخبار از طرف راکت هستید ؟