annotate vendor/plugins/redmine_bibliography/app/controllers/publications_controller.rb @ 534:cdec3eeaef7e feature_36

changes in the Query to retreive list of My Publications
author luisf <luis.figueira@eecs.qmul.ac.uk>
date Tue, 26 Jul 2011 14:35:11 +0100
parents ce1614b19759
children dd9d9c0ff0f9
rev   line source
luis@385 1 # vendor/plugins/redmine_bibliography/app/controllers/publications_controller.rb
luis@385 2
luis@328 3 class PublicationsController < ApplicationController
luis@425 4 unloadable
luis@457 5
luis@478 6 before_filter :find_project_by_project_id, :except => [:autocomplete_for_project, :add_author, :sort_authors, :autocomplete_for_author]
luis@519 7
luis@404 8 def new
luis@444 9 @publication = Publication.new
luis@445 10
luis@445 11 # we'll always want a new publication to have its bibtex entry
luis@480 12 # @publication.build_bibtex_entry
luis@445 13
luis@446 14 # and at least one author
luis@480 15 # @publication.authorships.build.build_author
luis@446 16
luis@458 17 @project_id = params[:project_id]
luis@467 18 @current_user = User.current
luis@519 19 end
luis@409 20
luis@384 21
luis@404 22 def create
luis@390 23 @publication = Publication.new(params[:publication])
luis@530 24
luis@530 25 logger.error { "PUBLICATION CREATE ACTION" }
luis@530 26 logger.error { params[:publication] }
luis@530 27
luis@530 28
luis@458 29 @project = Project.find(params[:project_id])
luis@445 30
luis@518 31 logger.error { "PARAMS publication" }
luis@518 32 logger.error { params[:publication] }
luis@530 33
luis@458 34 @publication.projects << @project
luis@458 35
luis@448 36 if @publication.save
luis@445 37 flash[:notice] = "Successfully created publication."
luis@459 38 redirect_to :action => :show, :id => @publication, :project_id => @project.id
luis@445 39 else
luis@445 40 render :action => 'new'
luis@445 41 end
luis@445 42 end
luis@445 43
luis@445 44 def index
luis@458 45 @project = Project.find(params[:project_id])
luis@458 46 @publications = Publication.find :all, :joins => :projects, :conditions => ["project_id = ?", @project.id]
luis@445 47 end
luis@445 48
luis@445 49 def new_from_bibfile
luis@391 50 @publication.current_step = session[:publication_step]
luis@409 51
luis@404 52 # contents of the paste text area
luis@404 53 bibtex_entry = params[:bibtex_entry]
luis@384 54
luis@404 55 # method for creating "pasted" bibtex entries
luis@424 56 if bibtex_entry
luis@409 57 parse_bibtex_list bibtex_entry
luis@404 58 end
luis@329 59 end
luis@329 60
luis@467 61 def add_author
luis@467 62 if (request.xhr?)
luis@467 63 render :text => User.find(params[:user_id]).name
luis@467 64 else
luis@467 65 # No? Then render an action.
luis@467 66 #render :action => 'view_attribute', :attr => @name
luis@467 67 logger.error { "ERRO ADD AUTHOR" }
luis@467 68 end
luis@467 69 end
luis@467 70
luis@445 71 def edit
luis@428 72 @publication = Publication.find(params[:id])
luis@430 73 end
luis@430 74
luis@445 75 def update
luis@448 76 @publication = Publication.find(params[:id])
luis@430 77 if @publication.update_attributes(params[:publication])
luis@430 78 flash[:notice] = "Successfully updated Publication."
luis@448 79 redirect_to @publication
luis@430 80 else
luis@448 81 render :action => 'edit'
luis@448 82 end
luis@328 83 end
luis@328 84
luis@425 85 def show
luis@430 86 logger.error "-------> No Show"
luis@430 87
luis@428 88 @publication = Publication.find(params[:id])
luis@425 89
luis@425 90 if @publication.nil?
luis@425 91 @publications = Publication.all
luis@425 92 render "index", :alert => 'Your Publications was not found!'
luis@425 93 else
luis@425 94 @authors = @publication.authors
luis@425 95 @bibtext_entry = @publication.bibtex_entry
luis@425 96
luis@425 97 respond_to do |format|
luis@425 98 format.html
luis@425 99 format.xml {render :xml => @publication}
luis@425 100 end
luis@425 101 end
luis@329 102 end
luis@329 103
luis@406 104 # parse string with bibtex authors
luis@406 105 def parse_authors(authors_entry)
luis@406 106 # in bibtex the authors are always seperated by "and"
luis@407 107 return authors_entry.split(" and ")
luis@406 108 end
luis@406 109
luis@406 110 # parses a list of bibtex
luis@406 111 def parse_bibtex_list(bibtex_list)
luis@406 112 bibliography = BibTeX.parse bibtex_list
luis@406 113
luis@406 114 no_entries = bibliography.data.length
luis@406 115
luis@406 116 # parses the bibtex entries
luis@406 117 bibliography.data.map do |d|
luis@407 118
luis@407 119 if d.class == BibTeX::Entry
luis@407 120 create_bibtex_entry d
luis@407 121 end
luis@406 122 end
luis@407 123 end
luis@407 124
luis@409 125 def create_bibtex_entry(d)
luis@407 126 @publication = Publication.new
luis@407 127 @bentry = BibtexEntry.new
luis@407 128 authors = []
luis@407 129 institution = ""
luis@407 130 email = ""
luis@409 131
luis@407 132 d.fields.keys.map do |field|
luis@407 133 case field.to_s
luis@407 134 when "author"
luis@407 135 authors = parse_authors d[field]
luis@407 136 when "title"
luis@407 137 @publication.title = d[field]
luis@407 138 when "institution"
luis@407 139 institution = d[field]
luis@407 140 when "email"
luis@407 141 email = d[field]
luis@407 142 else
luis@407 143 @bentry[field] = d[field]
luis@407 144 end
luis@407 145 end
luis@406 146
luis@406 147 @publication.bibtex_entry = @bentry
luis@407 148 @publication.save
luis@409 149
luis@424 150 # what is this for???
luis@424 151 # @created_publications << @publication.id
luis@409 152
luis@407 153 # need to save all authors
luis@407 154 # and establish the author-publication association
luis@407 155 # via the authorships table
luis@407 156 authors.each_with_index.map do |authorname, idx|
luis@407 157 author = Author.new(:name => authorname)
luis@407 158 if author.save!
luis@407 159 puts "SAVED"
luis@407 160 else
luis@407 161 puts "NOT SAVED"
luis@406 162 end
luis@406 163
luis@407 164 author.authorships.create!(
luis@444 165 :publication => @publication,
luis@444 166 :institution => institution,
luis@444 167 :email => email,
luis@444 168 :order => idx)
luis@407 169 end
luis@407 170 end
luis@409 171
luis@407 172 # parses the bibtex file
luis@407 173 def parse_bibtex_file
luis@407 174
luis@406 175 end
luis@406 176
luis@444 177 def import
luis@444 178 @publication = Publication.new
luis@444 179
luis@444 180
luis@444 181 end
luis@461 182
luis@461 183 def add_project
luis@464 184 @projects = Project.find(params[:publication][:project_ids])
luis@464 185 @publication = Publication.find(params[:id])
luis@464 186 @publication.projects << @projects
luis@461 187
luis@464 188 # TODO luisf should also respond to HTML???
luis@464 189 respond_to do |format|
luis@464 190 format.js
luis@464 191 end
luis@461 192 end
luis@409 193
luis@461 194 def autocomplete_for_project
luis@461 195 @publication = Publication.find(params[:id])
luis@477 196
luis@464 197 @projects = Project.active.like(params[:q]).find(:all, :limit => 100) - @publication.projects
luis@461 198 logger.debug "Query for \"#{params[:q]}\" returned \"#{@projects.size}\" results"
luis@461 199 render :layout => false
luis@409 200 end
luis@471 201
luis@477 202 def autocomplete_for_author
luis@519 203 @results = []
luis@480 204
luis@480 205 authors_list = Author.like(params[:q]).find(:all, :limit => 100)
luis@480 206 users_list = User.active.like(params[:q]).find(:all, :limit => 100)
luis@480 207
luis@519 208 logger.debug "Query for \"#{params[:q]}\" returned \"#{authors_list.size}\" authors and \"#{users_list.size}\" users"
luis@480 209
luis@480 210 # need to subtract both lists
luis@519 211 # give priority to the users
luis@519 212 users_list.each do |user|
luis@519 213 @results << user
luis@519 214 end
luis@480 215
luis@519 216 authors_list.each do |author|
luis@519 217 @results << author unless users_list.include?(author.user_id)
luis@480 218 end
luis@519 219
luis@477 220 render :layout => false
luis@477 221 end
luis@471 222
luis@471 223 def sort_authors
luis@471 224 params[:authors].each_with_index do |id, index|
luis@471 225 Author.update_all(['order=?', index+1], ['id=?', id])
luis@471 226 end
luis@471 227 render :nothing => true
luis@471 228 end
luis@471 229
luis@478 230 def identify_author
luis@478 231
luis@478 232 end
luis@478 233
luis@478 234
luis@457 235
luis@457 236 private
luis@457 237
luis@459 238 # TODO: luisf. - only here for debugging purposes
luis@459 239 # Find project of id params[:project_id]
luis@459 240 def find_project_by_project_id
luis@459 241
luis@459 242 logger.error { "FIND PROJECT BY PROJECT ID" }
luis@459 243
luis@459 244 @project = Project.find(params[:project_id])
luis@459 245 rescue ActiveRecord::RecordNotFound
luis@459 246 render_404
luis@459 247 end
luis@328 248 end