From ff65a5b22a5441476320a461c986a64b84ee025a Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Mon, 1 Jan 2007 11:26:56 +0000 Subject: [PATCH] added multiple file upload for documents and files modules git-svn-id: http://redmine.rubyforge.org/svn/trunk@130 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- app/controllers/documents_controller.rb | 10 ++++---- app/controllers/projects_controller.rb | 32 +++++++++++-------------- app/views/documents/show.rhtml | 7 +++--- app/views/projects/add_document.rhtml | 5 ++-- app/views/projects/add_file.rhtml | 5 ++-- public/javascripts/application.js | 1 - public/stylesheets/application.css | 1 + 7 files changed, 29 insertions(+), 32 deletions(-) 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 %>

<%= submit_tag l(:button_create) %> diff --git a/app/views/projects/add_file.rhtml b/app/views/projects/add_file.rhtml index cb478cb1..41c20843 100644 --- a/app/views/projects/add_file.rhtml +++ b/app/views/projects/add_file.rhtml @@ -7,8 +7,9 @@

<%= 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