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