] * @param int $id * @return \Illuminate\Contracts\View\View * @throws \Illuminate\Auth\Access\AuthorizationException */ public function create($id) { if ($accessory = Accessory::withCount('users as users_count')->find($id)) { $this->authorize('checkout', $accessory); if ($accessory->category) { // Make sure there is at least one available to checkout if ($accessory->numRemaining() <= 0){ return redirect()->route('accessories.index')->with('error', trans('admin/accessories/message.checkout.unavailable')); } // Return the checkout view return view('accessories/checkout', compact('accessory')); } // Invalid category return redirect()->route('accessories.edit', ['accessory' => $accessory->id]) ->with('error', trans('general.invalid_item_category_single', ['type' => trans('general.accessory')])); } // Not found return redirect()->route('accessories.index')->with('error', trans('admin/accessories/message.not_found')); } /** * Save the Accessory checkout information. * * If Slack is enabled and/or asset acceptance is enabled, it will also * trigger a Slack message and send an email. * * @author [A. Gianotto] [] * @param Request $request * @param int $accessoryId * @return \Illuminate\Http\RedirectResponse * @throws \Illuminate\Auth\Access\AuthorizationException */ public function store(Request $request, $accessoryId) { // Check if the accessory exists if (is_null($accessory = Accessory::withCount('users as users_count')->find($accessoryId))) { // Redirect to the accessory management page with error return redirect()->route('accessories.index')->with('error', trans('admin/accessories/message.user_not_found')); } $this->authorize('checkout', $accessory); if (!$user = User::find($request->input('assigned_to'))) { return redirect()->route('accessories.checkout.show', $accessory->id)->with('error', trans('admin/accessories/message.checkout.user_does_not_exist')); } // Make sure there is at least one available to checkout if ($accessory->numRemaining() <= 0){ return redirect()->route('accessories.index')->with('error', trans('admin/accessories/message.checkout.unavailable')); } // Update the accessory data $accessory->assigned_to = e($request->input('assigned_to')); $accessory->users()->attach($accessory->id, [ 'accessory_id' => $accessory->id, 'created_at' => Carbon::now(), 'user_id' => Auth::id(), 'assigned_to' => $request->get('assigned_to'), 'note' => $request->input('note'), ]); DB::table('accessories_users')->where('assigned_to', '=', $accessory->assigned_to)->where('accessory_id', '=', $accessory->id)->first(); event(new CheckoutableCheckedOut($accessory, $user, auth()->user(), $request->input('note'))); // Redirect to the new accessory page return redirect()->route('accessories.index')->with('success', trans('admin/accessories/message.checkout.success')); } }