forked from extern/egroupware
File upload bugfixes:
- Javascript error uploading files with ' in their name - uploading the same file twice to a customfield did not show the file uploaded properly
This commit is contained in:
parent
c88feccdf2
commit
d53335bbbf
@ -544,7 +544,7 @@ var et2_file = (function(){ "use strict"; return et2_inputWidget.extend(
|
|||||||
if(this.progress)
|
if(this.progress)
|
||||||
{
|
{
|
||||||
var fileName = file.fileName || 'file';
|
var fileName = file.fileName || 'file';
|
||||||
var status = jQuery("<li data-file='"+fileName+"'>"+fileName
|
var status = jQuery("<li data-file='"+fileName.replace(/'/g, '"')+"'>"+fileName
|
||||||
+"<div class='remove'/><span class='progressBar'><p/></span></li>")
|
+"<div class='remove'/><span class='progressBar'><p/></span></li>")
|
||||||
.appendTo(this.progress);
|
.appendTo(this.progress);
|
||||||
jQuery("div.remove",status).on('click', file, jQuery.proxy(this.cancel,this));
|
jQuery("div.remove",status).on('click', file, jQuery.proxy(this.cancel,this));
|
||||||
@ -561,7 +561,7 @@ var et2_file = (function(){ "use strict"; return et2_inputWidget.extend(
|
|||||||
_fileProgress: function(file) {
|
_fileProgress: function(file) {
|
||||||
if(this.progress)
|
if(this.progress)
|
||||||
{
|
{
|
||||||
jQuery("li[data-file='"+file.fileName+"'] > span.progressBar > p").css("width", Math.ceil(file.progress()*100)+"%");
|
jQuery("li[data-file='"+file.fileName.replace(/'/g, '"')+"'] > span.progressBar > p").css("width", Math.ceil(file.progress()*100)+"%");
|
||||||
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
@ -584,7 +584,7 @@ var et2_file = (function(){ "use strict"; return et2_inputWidget.extend(
|
|||||||
if(typeof response.response[0].data[key] == "string")
|
if(typeof response.response[0].data[key] == "string")
|
||||||
{
|
{
|
||||||
// Message from server - probably error
|
// Message from server - probably error
|
||||||
jQuery("[data-file='"+name+"']",this.progress)
|
jQuery("[data-file='"+name.replace(/'/g, '"')+"']",this.progress)
|
||||||
.addClass("error")
|
.addClass("error")
|
||||||
.css("display", "block")
|
.css("display", "block")
|
||||||
.text(response.response[0].data[key]);
|
.text(response.response[0].data[key]);
|
||||||
@ -599,14 +599,14 @@ var et2_file = (function(){ "use strict"; return et2_inputWidget.extend(
|
|||||||
}
|
}
|
||||||
if(this.progress)
|
if(this.progress)
|
||||||
{
|
{
|
||||||
jQuery("[data-file='"+name+"']",this.progress).addClass("message success");
|
jQuery("[data-file='"+name.replace(/'/g, '"')+"']",this.progress).addClass("message success");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (this.progress)
|
else if (this.progress)
|
||||||
{
|
{
|
||||||
jQuery("[data-file='"+name+"']",this.progress)
|
jQuery("[data-file='"+name.replace(/'/g, '"')+"']",this.progress)
|
||||||
.addClass("ui-state-error")
|
.addClass("ui-state-error")
|
||||||
.css("display", "block")
|
.css("display", "block")
|
||||||
.text(this.egw().lang("Server error"));
|
.text(this.egw().lang("Server error"));
|
||||||
@ -640,7 +640,7 @@ var et2_file = (function(){ "use strict"; return et2_inputWidget.extend(
|
|||||||
if(this.options.value[key].name == file.fileName)
|
if(this.options.value[key].name == file.fileName)
|
||||||
{
|
{
|
||||||
delete this.options.value[key];
|
delete this.options.value[key];
|
||||||
jQuery('[data-file="'+file.fileName+'"]',this.node).remove();
|
jQuery('[data-file="'+file.fileName.replace(/'/g, '"')+'"]',this.node).remove();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -291,7 +291,7 @@ var et2_link_to = (function(){ "use strict"; return et2_inputWidget.extend(
|
|||||||
id: file,
|
id: file,
|
||||||
name: self.file_upload.options.value[file].name,
|
name: self.file_upload.options.value[file].name,
|
||||||
type: self.file_upload.options.value[file].type,
|
type: self.file_upload.options.value[file].type,
|
||||||
remark: jQuery("li[file='"+self.file_upload.options.value[file].name+"'] > input", self.file_upload.progress)
|
remark: jQuery("li[file='"+self.file_upload.options.value[file].name.replace(/'/g, '"')+"'] > input", self.file_upload.progress)
|
||||||
.filter(function() { return jQuery(this).attr("placeholder") != jQuery(this).val();}).val()
|
.filter(function() { return jQuery(this).attr("placeholder") != jQuery(this).val();}).val()
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -720,7 +720,7 @@ var et2_vfsUpload = (function(){ "use strict"; return et2_file.extend(
|
|||||||
if(sender !== this && sender._type.indexOf('vfs') >= 0 )
|
if(sender !== this && sender._type.indexOf('vfs') >= 0 )
|
||||||
{
|
{
|
||||||
var value = sender.getValue && sender.getValue() || sender.options.value || {};
|
var value = sender.getValue && sender.getValue() || sender.options.value || {};
|
||||||
var row = jQuery('[data-path="'+(value.path)+'"]',this.list);
|
var row = jQuery("[data-path='"+(value.path.replace(/'/g, '"'))+"']",this.list);
|
||||||
if(sender._type === 'vfs-mime')
|
if(sender._type === 'vfs-mime')
|
||||||
{
|
{
|
||||||
return jQuery('.icon',row).get(0) || null;
|
return jQuery('.icon',row).get(0) || null;
|
||||||
@ -750,9 +750,41 @@ var et2_vfsUpload = (function(){ "use strict"; return et2_file.extend(
|
|||||||
return extra;
|
return extra;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A file upload is finished, update the UI
|
||||||
|
*/
|
||||||
|
finishUpload: function(file, response) {
|
||||||
|
var result = this._super.apply(this, arguments);
|
||||||
|
|
||||||
|
if(typeof response == 'string') response = jQuery.parseJSON(response);
|
||||||
|
if(response.response[0] && typeof response.response[0].data.length == 'undefined') {
|
||||||
|
for(var key in response.response[0].data) {
|
||||||
|
var value = response.response[0].data[key];
|
||||||
|
if(value && value.path)
|
||||||
|
{
|
||||||
|
this._addFile(value);
|
||||||
|
jQuery("[data-file='"+file.fileName.replace(/'/g, '"')+"']",this.progress).hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
},
|
||||||
|
|
||||||
_addFile: function(file_data) {
|
_addFile: function(file_data) {
|
||||||
|
if(jQuery("[data-path='"+file_data.path.replace(/'/g, '"')+"']").remove().length)
|
||||||
|
{
|
||||||
|
for(var child_index = this._children.length-1; child_index >= 0; child_index--)
|
||||||
|
{
|
||||||
|
var child = this._children[child_index];
|
||||||
|
if(child.options.value.path === file_data.path)
|
||||||
|
{
|
||||||
|
this.removeChild(child);
|
||||||
|
child.free();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
var row = jQuery(document.createElement("tr"))
|
var row = jQuery(document.createElement("tr"))
|
||||||
.attr("data-path", file_data.path)
|
.attr("data-path", file_data.path.replace(/'/g, '"'))
|
||||||
.attr("draggable", "true")
|
.attr("draggable", "true")
|
||||||
.appendTo(this.list);
|
.appendTo(this.list);
|
||||||
var mime = jQuery(document.createElement("td"))
|
var mime = jQuery(document.createElement("td"))
|
||||||
@ -782,7 +814,7 @@ var et2_vfsUpload = (function(){ "use strict"; return et2_file.extend(
|
|||||||
{
|
{
|
||||||
egw.json("filemanager_ui::ajax_action", [
|
egw.json("filemanager_ui::ajax_action", [
|
||||||
'delete',
|
'delete',
|
||||||
[row.attr('data-path')],
|
[row.attr('data-path').replace(/"/g, "'")],
|
||||||
''
|
''
|
||||||
],
|
],
|
||||||
function(data) {
|
function(data) {
|
||||||
|
Loading…
Reference in New Issue
Block a user