1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- class ActivitiesController < ApplicationController
- include GroupsHelper
- before_action :set_activity, only: [:show, :edit, :update, :destroy]
- before_action :set_group
- before_action :require_membership!
- # GET /groups/:id/activities
- # GET /activities.json
- def index
- @activities = @group.activities
- end
- # GET /activities/1
- # GET /activities/1.json
- def show
- end
- # GET /activities/new
- def new
- @activity = Activity.new
- end
- # GET /activities/1/edit
- def edit
- end
- # POST /activities
- # POST /activities.json
- def create
- @activity = Activity.new(activity_params)
- @activity.group = @group
- respond_to do |format|
- if @activity.save
- format.html { redirect_to group_activity_url(@group, @activity), notice: 'Activity was successfully created.' }
- format.json { render :show, status: :created, location: @activity }
- else
- format.html { render :new }
- format.json { render json: @activity.errors, status: :unprocessable_entity }
- end
- end
- end
- # PATCH/PUT /activities/1
- # PATCH/PUT /activities/1.json
- def update
- respond_to do |format|
- if @activity.update(activity_params)
- format.html { redirect_to group_activity_url(@group, @activity), notice: 'Activity was successfully updated.' }
- format.json { render :show, status: :ok, location: @activity }
- else
- format.html { render :edit }
- format.json { render json: @activity.errors, status: :unprocessable_entity }
- end
- end
- end
- # DELETE /activities/1
- # DELETE /activities/1.json
- def destroy
- @activity.destroy
- respond_to do |format|
- format.html { redirect_to group_activities_url(@group), notice: 'Activity was successfully destroyed.' }
- format.json { head :no_content }
- end
- end
- private
- # Use callbacks to share common setup or constraints between actions.
- def set_activity
- @activity = Activity.find(params[:id])
- end
- def set_group
- @group = Group.find(params[:group_id])
- end
- # Never trust parameters from the scary internet, only allow the white list through.
- def activity_params
- params.require(:activity).permit(:public_name, :secret_name, :description, :location, :start, :end, :deadline, :show_hidden)
- end
- end
|