* work on Issue 142: Copy Folder option
git-svn-id: http://redmine-dmsf.googlecode.com/svn/trunk/redmine_dmsf@251 5e329b0b-a2ee-ea63-e329-299493fc886d
This commit is contained in:
parent
2360af7707
commit
d1d793e41c
@ -59,59 +59,23 @@ class DmsfFilesCopyController < ApplicationController
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
name = @file.name
|
new_file = @file.copy_to(@target_project, @target_folder)
|
||||||
|
|
||||||
file = DmsfFile.find_file_by_name(@target_project, @target_folder, name)
|
unless new_file.errors.empty?
|
||||||
if file.nil?
|
flash[:error] = "#{l(:error_file_cannot_be_copied)}: #{new_file.errors.full_messages.join(", ")}"
|
||||||
file = DmsfFile.new
|
|
||||||
file.project = @target_project
|
|
||||||
file.name = name
|
|
||||||
file.folder = @target_folder
|
|
||||||
file.notification = !Setting.plugin_redmine_dmsf["dmsf_default_notifications"].blank?
|
|
||||||
else
|
|
||||||
if file.locked_for_user?
|
|
||||||
flash[:error] = l(:error_file_is_locked)
|
|
||||||
redirect_to :action => "new", :id => @file, :target_project_id => @target_project, :target_folder_id => @target_folder
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
last_revision = @file.last_revision
|
|
||||||
|
|
||||||
new_revision = DmsfFileRevision.new
|
|
||||||
new_revision.folder = @target_folder
|
|
||||||
new_revision.file = file
|
|
||||||
new_revision.project = file.project
|
|
||||||
new_revision.user = User.current
|
|
||||||
new_revision.name = name
|
|
||||||
new_revision.title = @file.title
|
|
||||||
new_revision.description = @file.description
|
|
||||||
new_revision.comment = l(:comment_copied_from, :source => "#{@project.identifier}:#{@file.dmsf_path_str}")
|
|
||||||
new_revision.source_revision = last_revision
|
|
||||||
new_revision.major_version = last_revision.major_version
|
|
||||||
new_revision.minor_version = last_revision.minor_version
|
|
||||||
new_revision.workflow = last_revision.workflow
|
|
||||||
new_revision.mime_type = last_revision.mime_type
|
|
||||||
new_revision.size = last_revision.size
|
|
||||||
new_revision.disk_filename = last_revision.disk_filename
|
|
||||||
|
|
||||||
if file.save && new_revision.save
|
|
||||||
file.reload
|
|
||||||
else
|
|
||||||
flash[:error] = error_messages_for(file)
|
|
||||||
redirect_to :action => "new", :id => @file, :target_project_id => @target_project, :target_folder_id => @target_folder
|
redirect_to :action => "new", :id => @file, :target_project_id => @target_project, :target_folder_id => @target_folder
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
flash[:notice] = l(:notice_file_copied)
|
flash[:notice] = l(:notice_file_copied)
|
||||||
log_activity(file, "was copied (is copy)")
|
log_activity(new_file, "was copied (is copy)")
|
||||||
begin
|
begin
|
||||||
DmsfMailer.deliver_files_updated(User.current, [file])
|
DmsfMailer.deliver_files_updated(User.current, [new_file])
|
||||||
rescue ActionView::MissingTemplate => e
|
rescue ActionView::MissingTemplate => e
|
||||||
Rails.logger.error "Could not send email notifications: " + e
|
Rails.logger.error "Could not send email notifications: " + e
|
||||||
end
|
end
|
||||||
|
|
||||||
redirect_to :controller => "dmsf_files", :action => "show", :id => file
|
redirect_to :controller => "dmsf_files", :action => "show", :id => new_file
|
||||||
end
|
end
|
||||||
|
|
||||||
def move
|
def move
|
||||||
@ -132,39 +96,23 @@ class DmsfFilesCopyController < ApplicationController
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
if @file.locked_for_user?
|
unless @file.move_to(@target_project, @target_folder)
|
||||||
flash[:error] = l(:error_file_is_locked)
|
flash[:error] = "#{l(:error_file_cannot_be_moved)}: #{@file.errors.full_messages.join(", ")}"
|
||||||
redirect_to :action => "new", :id => @file, :target_project_id => @target_project, :target_folder_id => @target_folder
|
redirect_to :action => "new", :id => @file, :target_project_id => @target_project, :target_folder_id => @target_folder
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
new_revision = @file.last_revision.clone
|
@file.reload
|
||||||
|
|
||||||
new_revision.folder = @target_folder
|
|
||||||
new_revision.project = @target_project
|
|
||||||
new_revision.comment = l(:comment_moved_from, :source => "#{@project.identifier}:#{@file.dmsf_path_str}")
|
|
||||||
|
|
||||||
@file.folder = @target_folder
|
|
||||||
@file.project = @target_project
|
|
||||||
|
|
||||||
if @file.save && new_revision.save
|
|
||||||
@file.reload
|
|
||||||
else
|
|
||||||
flash[:error] = error_messages_for(@file)
|
|
||||||
redirect_to :action => "new", :id => @file, :target_project_id => @target_project, :target_folder_id => @target_folder
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
flash[:notice] = l(:notice_file_moved)
|
flash[:notice] = l(:notice_file_moved)
|
||||||
log_activity(@file, "was moved (is copy)")
|
log_activity(@file, "was moved (is copy)")
|
||||||
begin
|
begin
|
||||||
|
# TODO: implement proper mail notification
|
||||||
DmsfMailer.deliver_files_updated(User.current, [@file])
|
DmsfMailer.deliver_files_updated(User.current, [@file])
|
||||||
rescue ActionView::MissingTemplate => e
|
rescue ActionView::MissingTemplate => e
|
||||||
Rails.logger.error "Could not send email notifications: " + e
|
Rails.logger.error "Could not send email notifications: " + e
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO: implement proper mail notification
|
|
||||||
|
|
||||||
redirect_to :controller => "dmsf_files", :action => "show", :id => @file
|
redirect_to :controller => "dmsf_files", :action => "show", :id => @file
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@ -83,14 +83,6 @@ class DmsfFile < ActiveRecord::Base
|
|||||||
def last_revision
|
def last_revision
|
||||||
self.revisions.first
|
self.revisions.first
|
||||||
end
|
end
|
||||||
|
|
||||||
#def revisions(offset = nil, limit = nil)
|
|
||||||
# DmsfFileRevision.find(:all, :conditions =>
|
|
||||||
# ["dmsf_file_id = :file_id and deleted = :deleted",
|
|
||||||
# {:file_id => self.id, :deleted => false}],
|
|
||||||
# :order => "major_version DESC, minor_version DESC, updated_at DESC",
|
|
||||||
# :limit => limit, :offset => offset)
|
|
||||||
#end
|
|
||||||
|
|
||||||
def delete
|
def delete
|
||||||
if locked_for_user?
|
if locked_for_user?
|
||||||
@ -195,6 +187,43 @@ class DmsfFile < ActiveRecord::Base
|
|||||||
projects
|
projects
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def move_to(project, folder)
|
||||||
|
if self.locked_for_user?
|
||||||
|
errors.add_to_base(l(:error_file_is_locked))
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
new_revision = self.last_revision.clone
|
||||||
|
|
||||||
|
new_revision.folder = folder ? folder : nil
|
||||||
|
new_revision.project = folder ? folder.project : project
|
||||||
|
new_revision.comment = l(:comment_moved_from, :source => "#{self.project.identifier}:#{self.dmsf_path_str}")
|
||||||
|
|
||||||
|
self.folder = new_revision.folder
|
||||||
|
self.project = new_revision.project
|
||||||
|
|
||||||
|
return self.save && new_revision.save
|
||||||
|
end
|
||||||
|
|
||||||
|
def copy_to(project, folder)
|
||||||
|
file = DmsfFile.new
|
||||||
|
file.folder = folder ? folder : nil
|
||||||
|
file.project = folder ? folder.project : project
|
||||||
|
file.name = self.name
|
||||||
|
file.notification = !Setting.plugin_redmine_dmsf["dmsf_default_notifications"].blank?
|
||||||
|
|
||||||
|
new_revision = self.last_revision.clone
|
||||||
|
|
||||||
|
new_revision.file = file
|
||||||
|
new_revision.folder = folder ? folder : nil
|
||||||
|
new_revision.project = folder ? folder.project : project
|
||||||
|
new_revision.comment = l(:comment_copied_from, :source => "#{self.project.identifier}:#{self.dmsf_path_str}")
|
||||||
|
|
||||||
|
new_revision.save if file.save
|
||||||
|
|
||||||
|
return file
|
||||||
|
end
|
||||||
|
|
||||||
# To fullfill searchable module expectations
|
# To fullfill searchable module expectations
|
||||||
def self.search(tokens, projects=nil, options={})
|
def self.search(tokens, projects=nil, options={})
|
||||||
tokens = [] << tokens unless tokens.is_a?(Array)
|
tokens = [] << tokens unless tokens.is_a?(Array)
|
||||||
|
|||||||
@ -176,4 +176,6 @@ cs:
|
|||||||
:label_dmsf_folder_plural: "Dmsf složky"
|
:label_dmsf_folder_plural: "Dmsf složky"
|
||||||
:comment_moved_from: "Přesunuto z %{source}"
|
:comment_moved_from: "Přesunuto z %{source}"
|
||||||
:error_target_folder_same: "Cílový adresář a projekt jsou stejné jako aktuální"
|
:error_target_folder_same: "Cílový adresář a projekt jsou stejné jako aktuální"
|
||||||
|
:error_file_cannot_be_moved: "Soubor nemůže být přesunut"
|
||||||
|
:error_file_cannot_be_copied: "Soubor nemůže být zkopírován"
|
||||||
|
|
||||||
@ -177,4 +177,6 @@ de:
|
|||||||
:label_dmsf_folder_plural: "Dmsf folders"
|
:label_dmsf_folder_plural: "Dmsf folders"
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -172,4 +172,6 @@ en-GB:
|
|||||||
:label_dmsf_folder_plural: "Dmsf folders"
|
:label_dmsf_folder_plural: "Dmsf folders"
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -172,4 +172,6 @@ en-GB:
|
|||||||
:label_dmsf_folder_plural: "Dmsf folders"
|
:label_dmsf_folder_plural: "Dmsf folders"
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -176,4 +176,6 @@ en:
|
|||||||
:label_dmsf_folder_plural: "Dmsf folders"
|
:label_dmsf_folder_plural: "Dmsf folders"
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -174,4 +174,6 @@ es:
|
|||||||
:label_dmsf_folder_plural: "Dmsf folders"
|
:label_dmsf_folder_plural: "Dmsf folders"
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -172,4 +172,6 @@ fr:
|
|||||||
:label_dmsf_folder_plural: "Dmsf folders"
|
:label_dmsf_folder_plural: "Dmsf folders"
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -177,4 +177,6 @@ ja:
|
|||||||
#Not translated
|
#Not translated
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -178,4 +178,6 @@ ru:
|
|||||||
#Not translated
|
#Not translated
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
@ -179,4 +179,6 @@ zh:
|
|||||||
:label_dmsf_folder_plural: "Dmsf folders"
|
:label_dmsf_folder_plural: "Dmsf folders"
|
||||||
:comment_moved_from: "Moved from %{source}"
|
:comment_moved_from: "Moved from %{source}"
|
||||||
:error_target_folder_same: "Target folder and project are the same as current"
|
:error_target_folder_same: "Target folder and project are the same as current"
|
||||||
|
:error_file_cannot_be_moved: "File can't be moved"
|
||||||
|
:error_file_cannot_be_copied: "File can't be copied"
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user