131 lines
4.2 KiB
Ruby
131 lines
4.2 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)
|
|
|
|
if params[:query].present?
|
|
query_str = "%#{params[:query]}%"
|
|
# Durchsucht Name, SKU, Seriennummer und deine Sticker-ID gleichzeitig
|
|
@items = @items.where(
|
|
"items.name LIKE :q OR items.sku LIKE :q OR items.serial_number LIKE :q OR items.sticker_id LIKE :q",
|
|
q: query_str
|
|
)
|
|
end
|
|
|
|
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
|