class TeamMembersController < ApplicationController before_filter :project # Authorize before_filter :add_project_abilities before_filter :authorize_read_project! before_filter :authorize_admin_project!, :only => [:new, :create, :destroy, :update] def show @team_member = project.users_projects.find(params[:id]) end def new @team_member = project.users_projects.new end def create @team_member = UsersProject.new(params[:team_member]) @team_member.project = project @team_member.save end def update @team_member = project.users_projects.find(params[:id]) @team_member.update_attributes(params[:team_member]) respond_to do |format| format.js format.html do unless @team_member.valid? flash[:alert] = "User should have at least one role" end redirect_to team_project_path(@project) end end end def destroy @team_member = project.users_projects.find(params[:id]) @team_member.destroy respond_to do |format| format.html { redirect_to root_path } format.js { render :nothing => true } end end end