] * @see ConsumablesController::getDatatable() method that generates the JSON response * @since [v1.0] * @return \Illuminate\Contracts\View\View * @throws \Illuminate\Auth\Access\AuthorizationException */ public function index() { $this->authorize('index', Consumable::class); return view('consumables/index'); } /** * Return a view to display the form view to create a new consumable * * @author [A. Gianotto] [] * @see ConsumablesController::postCreate() method that stores the form data * @since [v1.0] * @return \Illuminate\Contracts\View\View * @throws \Illuminate\Auth\Access\AuthorizationException */ public function create() { $this->authorize('create', Consumable::class); return view('consumables/edit')->with('category_type', 'consumable') ->with('item', new Consumable); } /** * Validate and store new consumable data. * * @author [A. Gianotto] [] * @see ConsumablesController::getCreate() method that returns the form view * @since [v1.0] * @param ImageUploadRequest $request * @return \Illuminate\Http\RedirectResponse * @throws \Illuminate\Auth\Access\AuthorizationException */ public function store(StoreConsumableRequest $request) { $this->authorize('create', Consumable::class); $consumable = new Consumable(); $consumable->name = $request->input('name'); $consumable->category_id = $request->input('category_id'); $consumable->supplier_id = $request->input('supplier_id'); $consumable->location_id = $request->input('location_id'); $consumable->company_id = Company::getIdForCurrentUser($request->input('company_id')); $consumable->order_number = $request->input('order_number'); $consumable->min_amt = $request->input('min_amt'); $consumable->manufacturer_id = $request->input('manufacturer_id'); $consumable->model_number = $request->input('model_number'); $consumable->item_no = $request->input('item_no'); $consumable->purchase_date = $request->input('purchase_date'); $consumable->purchase_cost = $request->input('purchase_cost'); $consumable->qty = $request->input('qty'); $consumable->created_by = auth()->id(); $consumable->notes = $request->input('notes'); $consumable = $request->handleImages($consumable); session()->put(['redirect_option' => $request->get('redirect_option')]); if ($consumable->save()) { return redirect()->to(Helper::getRedirectOption($request, $consumable->id, 'Consumables'))->with('success', trans('admin/consumables/message.create.success')); } return redirect()->back()->withInput()->withErrors($consumable->getErrors()); } /** * Returns a form view to edit a consumable. * * @author [A. Gianotto] [] * @param int $consumableId * @see ConsumablesController::postEdit() method that stores the form data. * @since [v1.0] */ public function edit($consumableId = null) : View | RedirectResponse { if ($item = Consumable::find($consumableId)) { $this->authorize($item); return view('consumables/edit', compact('item'))->with('category_type', 'consumable'); } return redirect()->route('consumables.index')->with('error', trans('admin/consumables/message.does_not_exist')); } /** * Returns a form view to edit a consumable. * * @author [A. Gianotto] [] * @param ImageUploadRequest $request * @param int $consumableId * @return \Illuminate\Http\RedirectResponse * @throws \Illuminate\Auth\Access\AuthorizationException * @see ConsumablesController::getEdit() method that stores the form data. * @since [v1.0] */ public function update(StoreConsumableRequest $request, $consumableId = null) { if (is_null($consumable = Consumable::find($consumableId))) { return redirect()->route('consumables.index')->with('error', trans('admin/consumables/message.does_not_exist')); } $min = $consumable->numCheckedOut(); $validator = Validator::make($request->all(), [ "qty" => "required|numeric|min:$min" ]); if ($validator->fails()) { return redirect()->back() ->withErrors($validator) ->withInput(); } $this->authorize($consumable); $consumable->name = $request->input('name'); $consumable->category_id = $request->input('category_id'); $consumable->supplier_id = $request->input('supplier_id'); $consumable->location_id = $request->input('location_id'); $consumable->company_id = Company::getIdForCurrentUser($request->input('company_id')); $consumable->order_number = $request->input('order_number'); $consumable->min_amt = $request->input('min_amt'); $consumable->manufacturer_id = $request->input('manufacturer_id'); $consumable->model_number = $request->input('model_number'); $consumable->item_no = $request->input('item_no'); $consumable->purchase_date = $request->input('purchase_date'); $consumable->purchase_cost = $request->input('purchase_cost'); $consumable->qty = Helper::ParseFloat($request->input('qty')); $consumable->notes = $request->input('notes'); $consumable = $request->handleImages($consumable); session()->put(['redirect_option' => $request->get('redirect_option')]); if ($consumable->save()) { return redirect()->to(Helper::getRedirectOption($request, $consumable->id, 'Consumables'))->with('success', trans('admin/consumables/message.update.success')); } return redirect()->back()->withInput()->withErrors($consumable->getErrors()); } /** * Delete a consumable. * * @author [A. Gianotto] [] * @param int $consumableId * @since [v1.0] * @return \Illuminate\Http\RedirectResponse * @throws \Illuminate\Auth\Access\AuthorizationException */ public function destroy($consumableId) { if (is_null($consumable = Consumable::find($consumableId))) { return redirect()->route('consumables.index')->with('error', trans('admin/consumables/message.not_found')); } $this->authorize($consumable); $consumable->delete(); // Redirect to the locations management page return redirect()->route('consumables.index')->with('success', trans('admin/consumables/message.delete.success')); } /** * Return a view to display component information. * * @author [A. Gianotto] [] * @see ConsumablesController::getDataView() method that generates the JSON response * @since [v1.0] * @param int $consumableId * @return \Illuminate\Contracts\View\View * @throws \Illuminate\Auth\Access\AuthorizationException */ public function show($consumableId = null) { $consumable = Consumable::withCount('users as users_consumables')->find($consumableId); $this->authorize($consumable); if (isset($consumable->id)) { return view('consumables/view', compact('consumable')); } return redirect()->route('consumables.index') ->with('error', trans('admin/consumables/message.does_not_exist')); } public function clone(Consumable $consumable) : View { $this->authorize('create', $consumable); $consumable_to_close = $consumable; $consumable = clone $consumable_to_close; $consumable->id = null; $consumable->image = null; $consumable->created_by = null; return view('consumables/edit')->with('item', $consumable); } }