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