Files
vault171/app/controllers/items_controller.rb
David Böhm a19cc6984f
Some checks failed
CI / scan_ruby (push) Has been cancelled
CI / scan_js (push) Has been cancelled
CI / lint (push) Has been cancelled
CI / test (push) Has been cancelled
CI / system-test (push) Has been cancelled
Updated/Fixed Item form and item show
2026-05-23 03:18:56 +02:00

122 lines
3.8 KiB
Ruby

class ItemsController < ApplicationController
before_action :set_item, only: %i[ show edit update destroy ]
# GET /items or /items.json
def index
@items = Item.all.includes(:category, :user, :room).order(created_at: :desc)
respond_to do |format|
format.html # Rendert ganz normal deine Bestandsliste im Browser
format.csv do
# Dateiname generieren, z.B. "inventar_export_2026-05-22.csv"
filename = "inventar_export_#{Time.current.strftime('%Y-%m-%d')}.csv"
# Daten generieren und als Download an den Browser senden
send_data Item.to_csv,
filename: filename,
type: "text/csv; charset=utf-8; header=present"
end
end
end
# GET /items/1 or /items/1.json
def show
@assignment_logs = @item.assignment_logs.includes(:user, :room).order(assigned_at: :desc)
end
# GET /items/new
def new
@item = Item.new
# Falls wir uns im Turbo-Frame befinden, rendern wir nur das Formular-Teilstück
render partial: "form", locals: { item: @item } if turbo_frame_request?
end
# GET /items/1/edit
def edit
# @item wird bereits über vorab gesetztes set_item geladen
render partial: "form", locals: { item: @item } if turbo_frame_request?
end
# POST /items or /items.json
def create
@item = Item.new(item_params)
# Text-Eingaben in echte IDs auflösen
resolve_assignment_names
respond_to do |format|
if @item.save
format.html { redirect_to @item, notice: "Artikel '#{@item.name}' wurde erfolgreich im System registriert." }
format.json { render :show, status: :created, location: @item }
else
format.html { render :new, status: :unprocessable_content }
format.json { render json: @item.errors, status: :unprocessable_content }
end
end
end
# PATCH/PUT /items/1 or /items/1.json
def update
@item.assign_attributes(item_params)
# Text-Eingaben in echte IDs auflösen
resolve_assignment_names
respond_to do |format|
if @item.save
format.html { redirect_to @item, notice: "Artikel '#{@item.name} wurde erfolgreich aktualisiert.", status: :see_other }
format.json { render :show, status: :ok, location: @item }
else
format.html { render :edit, status: :unprocessable_content }
format.json { render json: @item.errors, status: :unprocessable_content }
end
end
end
# DELETE /items/1 or /items/1.json
def destroy
@item.destroy!
respond_to do |format|
format.html { redirect_to items_path, notice: "Artikel wurde erfolgreich aus dem System gelöscht", status: :see_other }
format.json { head :no_content }
end
end
private
def set_item
@item = Item.find(params.expect(:id))
end
# Sucht anhand des eingetippten Namens den passenden Datenbank-Eintrag
def resolve_assignment_names
if params[:item][:user_name].present?
# Wir splitten den Namen in Vor- und Nachname auf
parts = params[:item][:user_name].split(" ")
user = User.find_by(first_name: parts[0], last_name: parts[1])
if user
@item.user_id = user.id
@item.room_id = nil # Sicherstellen, dass der Raum geleert wird
else
@item.errors.add(:base, "Der eingegebene Mitarbeiter existiert nicht im System.")
end
elsif params[:item][:room_name].present?
room = Room.find_by(name: params[:item][:room_name])
if room
@item.room_id = room.id
@item.user_id = nil # Sicherstellen, dass der User geleert wird
else
@item.errors.add(:base, "Der eingegebene Raum existiert nicht im System.")
end
end
end
def item_params
# 'user_name' und 'room_name' müssen in die Strong Parameters aufgenommen werden!
params.require(:item).permit(:name, :sku, :sticker_id, :serial_number, :price, :notes, :category_id, :user_id, :room_id, :user_name, :room_name)
end
end