diff --git a/app/controllers/documents_controller.rb b/app/controllers/documents_controller.rb index 3107b3ed..3cc8662e 100644 --- a/app/controllers/documents_controller.rb +++ b/app/controllers/documents_controller.rb @@ -46,12 +46,10 @@ class DocumentsController < ApplicationController end def add_attachment - # Save the attachment - if params[:attachment][:file].size > 0 - @attachment = @document.attachments.build(params[:attachment]) - @attachment.author_id = self.logged_in_user.id if self.logged_in_user - @attachment.save - end + # Save the attachments + params[:attachments].each { |a| + Attachment.create(:container => @document, :file => a, :author => logged_in_user) unless a.size == 0 + } if params[:attachments] and params[:attachments].is_a? Array redirect_to :action => 'show', :id => @document end diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb index 3a6986be..78a1e466 100644 --- a/app/controllers/projects_controller.rb +++ b/app/controllers/projects_controller.rb @@ -174,16 +174,13 @@ class ProjectsController < ApplicationController def add_document @categories = Enumeration::get_values('DCAT') @document = @project.documents.build(params[:document]) - if request.post? - # Save the attachment - if params[:attachment][:file].size > 0 - @attachment = @document.attachments.build(params[:attachment]) - @attachment.author_id = self.logged_in_user.id if self.logged_in_user - end - if @document.save - flash[:notice] = l(:notice_successful_create) - redirect_to :action => 'list_documents', :id => @project - end + if request.post? and @document.save + # Save the attachments + params[:attachments].each { |a| + Attachment.create(:container => @document, :file => a, :author => logged_in_user) unless a.size == 0 + } if params[:attachments] and params[:attachments].is_a? Array + flash[:notice] = l(:notice_successful_create) + redirect_to :action => 'list_documents', :id => @project end end @@ -360,14 +357,13 @@ class ProjectsController < ApplicationController end def add_file - @attachment = Attachment.new(params[:attachment]) - if request.post? and params[:attachment][:file].size > 0 - @attachment.container = @project.versions.find_by_id(params[:version_id]) - @attachment.author = logged_in_user - if @attachment.save - flash[:notice] = l(:notice_successful_create) - redirect_to :controller => 'projects', :action => 'list_files', :id => @project - end + if request.post? + @version = @project.versions.find_by_id(params[:version_id]) + # Save the attachments + params[:attachments].each { |a| + Attachment.create(:container => @version, :file => a, :author => logged_in_user) unless a.size == 0 + } if params[:attachments] and params[:attachments].is_a? Array + redirect_to :controller => 'projects', :action => 'list_files', :id => @project end @versions = @project.versions end diff --git a/app/views/documents/show.rhtml b/app/views/documents/show.rhtml index 385b2517..ace093dc 100644 --- a/app/views/documents/show.rhtml +++ b/app/views/documents/show.rhtml @@ -28,9 +28,10 @@ <% if authorize_for('documents', 'add_attachment') %> - <%= start_form_tag ({ :controller => 'documents', :action => 'add_attachment', :id => @document }, :multipart => true) %> - - <%= file_field 'attachment', 'file' %> + <%= start_form_tag ({ :controller => 'documents', :action => 'add_attachment', :id => @document }, :multipart => true, :class => "tabular") %> +
+ <%= file_field_tag 'attachments[]', :size => 30 %>
<%= submit_tag l(:button_add) %> <%= end_form_tag %> <% end %> diff --git a/app/views/projects/add_document.rhtml b/app/views/projects/add_document.rhtml index 88572f40..e788a7bc 100644 --- a/app/views/projects/add_document.rhtml +++ b/app/views/projects/add_document.rhtml @@ -4,8 +4,9 @@ <%= render :partial => 'documents/form' %>-<%= file_field 'attachment', 'file' %>
++<%= file_field_tag 'attachments[]', :size => 30 %>
<%= select_tag "version_id", options_from_collection_for_select(@versions, "id", "name") %>
--<%= file_field 'attachment', 'file' %>
++<%= file_field_tag 'attachments[]', :size => 30 %>
<%= submit_tag l(:button_add) %> <%= end_form_tag %> \ No newline at end of file diff --git a/public/javascripts/application.js b/public/javascripts/application.js index 46649130..3625914a 100644 --- a/public/javascripts/application.js +++ b/public/javascripts/application.js @@ -15,6 +15,5 @@ function addFileField() { p = document.getElementById("attachments_p"); p.appendChild(document.createElement("br")); - p.appendChild(document.createElement("br")); p.appendChild(f); } \ No newline at end of file diff --git a/public/stylesheets/application.css b/public/stylesheets/application.css index 71c19d8b..29ca3cf8 100644 --- a/public/stylesheets/application.css +++ b/public/stylesheets/application.css @@ -204,6 +204,7 @@ blockquote { input, select { vertical-align: middle; + margin-bottom: 4px; } input.button-small