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:
nathangray 2017-04-18 09:34:22 -06:00
parent c88feccdf2
commit d53335bbbf
3 changed files with 42 additions and 10 deletions

View File

@ -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, '&quot')+"'>"+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, '&quot')+"'] > 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, '&quot')+"']",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, '&quot')+"']",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, '&quot')+"']",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, '&quot')+'"]',this.node).remove();
return; return;
} }
} }

View File

@ -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, '&quot')+"'] > 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()
}); });
} }

View File

@ -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, '&quot'))+"']",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, '&quot')+"']",this.progress).hide();
}
}
}
return result;
},
_addFile: function(file_data) { _addFile: function(file_data) {
if(jQuery("[data-path='"+file_data.path.replace(/'/g, '&quot')+"']").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, '&quot'))
.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(/&quot/g, "'")],
'' ''
], ],
function(data) { function(data) {