2023-01-11 18:48:06 +02:00
|
|
|
class StoriesController < ApplicationController
|
|
|
|
before_action :set_story, only: %i[ show edit update destroy ]
|
|
|
|
|
|
|
|
def index
|
2023-01-24 00:22:29 +02:00
|
|
|
@q = Story.ransack(params[:q])
|
|
|
|
@q.sorts = 'created_at desc' if @q.sorts.empty?
|
|
|
|
@stories = @q.result(distinct: true).page( params[:page])
|
2023-01-11 18:48:06 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def show
|
|
|
|
end
|
|
|
|
|
|
|
|
def new
|
|
|
|
@story = Story.new
|
|
|
|
end
|
|
|
|
|
|
|
|
def edit
|
2023-01-15 22:00:26 +02:00
|
|
|
authorize @story
|
2023-01-11 18:48:06 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
@story = Story.new(story_params)
|
2023-01-11 20:52:58 +02:00
|
|
|
@story.member = current_member
|
2023-01-11 18:48:06 +02:00
|
|
|
|
|
|
|
if @story.save
|
|
|
|
redirect_to @story, notice: "Story was successfully created."
|
|
|
|
else
|
|
|
|
render :new, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
2023-01-22 13:17:27 +02:00
|
|
|
authorize @story
|
2023-01-11 18:48:06 +02:00
|
|
|
if @story.update(story_params)
|
|
|
|
redirect_to @story, notice: "Story was successfully updated."
|
|
|
|
else
|
|
|
|
render :edit, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
2023-01-22 13:17:27 +02:00
|
|
|
authorize @story
|
2023-01-11 18:48:06 +02:00
|
|
|
@story.destroy
|
|
|
|
redirect_to stories_url, notice: "Story was successfully destroyed."
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
# Use callbacks to share common setup or constraints between actions.
|
|
|
|
def set_story
|
|
|
|
@story = Story.find(params[:id])
|
|
|
|
end
|
|
|
|
|
|
|
|
# Only allow a list of trusted parameters through.
|
|
|
|
def story_params
|
|
|
|
params.require(:story).permit(:picture, :header, :text, :happened)
|
|
|
|
end
|
|
|
|
end
|