orderBy('is_default', 'desc') ->when(request('search'), function ($q) { $q->where(function ($q) { $q->where('name', 'like', '%' . request('search') . '%') ->orWhere('country_name', 'like', '%' . request('search') . '%') ->orWhere('code', 'like', '%' . request('search') . '%') ->orWhere('symbol', 'like', '%' . request('search') . '%'); }); }) ->latest() ->paginate($request->per_page ?? 20)->appends($request->query()); $user_currency = UserCurrency::where('business_id', auth()->user()->business_id)->first(); if ($request->ajax()) { return response()->json([ 'data' => view('business::currencies.datas', compact('currencies', 'user_currency'))->render() ]); } return view('business::currencies.index', compact('currencies','user_currency')); } public function default($id) { $currency = Currency::findOrFail($id); DB::beginTransaction(); try { $user_currency = UserCurrency::where('business_id', auth()->user()->business_id)->first(); if ($user_currency) { $user_currency->update([ 'name' => $currency->name, 'currency_id' => $currency->id, 'country_name' => $currency->country_name, 'code' => $currency->code, 'rate' => $currency->rate, 'symbol' => $currency->symbol, 'position' => $currency->position, ]); } else { UserCurrency::create([ 'currency_id' => $currency->id, 'business_id' => auth()->user()->business_id, 'name' => $currency->name, 'country_name' => $currency->country_name, 'code' => $currency->code, 'rate' => $currency->rate, 'symbol' => $currency->symbol, 'position' => $currency->position, ]); } // Clear update cache()->forget("business_currency_" . auth()->user()->business_id); DB::commit(); return redirect()->route('business.currencies.index')->with('message', __('Default currency activated successfully')); } catch (\Exception $e) { DB::rollBack(); return redirect()->route('business.currencies.index')->with('error', __('Failed to set default currency. Please try again.')); } } }