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