class TopicsController < ApplicationController before_filter :require_user, only: [:new, :create, :edit, :update] respond_to :html, :js, :json autocomplete :topic, :name, :full => true, :extra_data => [:user_id] # GET topics # or GET /users/:user_id/topics def index @current = current_user if params[:user_id] @user = User.find(params[:user_id]) @topics = Topic.order("name ASC").visibleToUser(@current, @user) elsif @topics = Topic.order("name ASC").visibleToUser(@current, nil) end respond_with(@user,@topics) end # Get topics/new def new @topic = Topic.new @user = current_user respond_with(@topic) end # GET topics/:id def show @current = current_user @topic = Topic.find(params[:id]).authorize_to_show(@current) if @topic @relatives = @topic.network_as_json(@current).html_safe else redirect_to root_url and return end respond_to do |format| format.html { respond_with(@topic, @user) } format.json { respond_with(@relatives) } end end # GET showcard/:id def showcard @user = current_user @topic = Topic.find(params[:id]).authorize_to_show(@user) respond_to do |format| format.html { respond_with(@topic, @user) } end end # POST topics def create @user = current_user # if the topic exists grab it and return it if params[:topic][:grabTopic] != "null" @topic = Topic.find(params[:topic][:grabTopic]) # if the topic doesn't exist yet, create it else @topic = Topic.new() @topic.name = params[:topic][:name] @topic.desc = "" @topic.link = "" @topic.permission = 'commons' @topic.metacode = Metacode.find_by_name(params[:topic][:metacode]) @topic.user = @user @topic.save end # pass on to the topic create js whether it's being created with a synapse @synapse = "false" if params[:topic][:addSynapse] == "true" @synapse = "true" end # also create an object to return the position to the canvas @position = Hash.new() @position['x'] = params[:topic][:x] @position['y'] = params[:topic][:y] # set this for the case where the topic is being created on a map. @mapping = Mapping.new() if params[:topic][:map] @mapping.category = "Topic" @mapping.user = @user @mapping.map = Map.find(params[:topic][:map]) @mapping.topic = @topic @mapping.xloc = params[:topic][:x] @mapping.yloc = params[:topic][:y] @mapping.save end respond_to do |format| format.html { respond_with(@user, location: topic_url(@topic)) } format.js { respond_with(@topic, @mapping, @synapse, @position) } end end # GET topics/:id/edit def edit @current = current_user @topic = Topic.find(params[:id]).authorize_to_edit(@current) if not @topic redirect_to root_url and return end respond_with(@topic) end # PUT topics/:id def update @current = current_user @topic = Topic.find(params[:id]).authorize_to_edit(@current) if @topic @topic.name = params[:topic][:name] @topic.desc = params[:topic][:desc] @topic.link = params[:topic][:link] @topic.permission = params[:topic][:permission] @topic.metacode = Metacode.find(params[:category][:metacode_id]) @topic.save end respond_with(@user, location: topic_url(@topic)) do |format| end end # DELETE topics/:id def destroy @current = current_user @topic = Topic.find(params[:id]).authorize_to_edit(@current) if @topic @synapses = @topic.synapses @mappings = @topic.mappings @synapses.each do |synapse| synapse.delete end @mappings.each do |mapping| mapping.delete end @topic.delete end respond_to do |format| format.js end end end