Add filemanager custom field type using vfs-upload

This commit is contained in:
Nathan Gray 2015-09-02 19:52:47 +00:00
parent 687d90c37a
commit 31a23f0dbd
7 changed files with 156 additions and 24 deletions

View File

@ -90,6 +90,7 @@ class customfields
'ajax_select' => array('cf_values' => true), 'ajax_select' => array('cf_values' => true),
'radio' => array('cf_values' => true), 'radio' => array('cf_values' => true),
'checkbox' => array('cf_values' => true), 'checkbox' => array('cf_values' => true),
'filemanager' => array('cf_values' => true),
); );
/** /**

View File

@ -41,7 +41,6 @@ class etemplate_widget_customfields extends etemplate_widget_transformer
'select-account' => 'Select account', 'select-account' => 'Select account',
'button' => 'Button', // button to execute javascript 'button' => 'Button', // button to execute javascript
'url' => 'Url', 'url' => 'Url',
'url-email'=> 'EMail',
'url-phone'=> 'Phone number', 'url-phone'=> 'Phone number',
'htmlarea' => 'Formatted Text (HTML)', 'htmlarea' => 'Formatted Text (HTML)',
'link-entry' => 'Select entry', // should be last type, as the individual apps get added behind 'link-entry' => 'Select entry', // should be last type, as the individual apps get added behind
@ -264,9 +263,16 @@ class etemplate_widget_customfields extends etemplate_widget_transformer
$type = $field['type']; $type = $field['type'];
// Link-tos needs to change from appname to link-to // Link-tos needs to change from appname to link-to
if($link_types[$field['type']]) if($link_types[$field['type']])
{
if($type == 'filemanager')
{
$type = 'vfs-upload';
}
else
{ {
$type = 'link-to'; $type = 'link-to';
} }
}
$widget = self::factory($type, '<'.$type.' type="'.$type.'" id="'.self::$prefix.$fname.'"/>', self::$prefix.$fname); $widget = self::factory($type, '<'.$type.' type="'.$type.'" id="'.self::$prefix.$fname.'"/>', self::$prefix.$fname);
$widget->id = self::$prefix.$fname; $widget->id = self::$prefix.$fname;
$widget->attrs['type'] = $type; $widget->attrs['type'] = $type;
@ -281,6 +287,12 @@ class etemplate_widget_customfields extends etemplate_widget_transformer
if($field['values']['max']) $widget->attrs['min'] = $field['values']['max']; if($field['values']['max']) $widget->attrs['min'] = $field['values']['max'];
break; break;
case 'vfs-upload':
$widget->attrs['path'] = $field['app'] . ':' .
self::expand_name('$cont['.egw_link::get_registry($field['app'],'view_id').']',0,0,0,0,self::$request->content).
':'.$field['label'];
break;
case 'link-to': case 'link-to':
$widget->attrs['only_app'] = $field['type']; $widget->attrs['only_app'] = $field['type'];
break; break;

View File

@ -31,12 +31,21 @@ class etemplate_widget_vfs extends etemplate_widget_file
*/ */
public function beforeSendToClient($cname, $expand = array()) public function beforeSendToClient($cname, $expand = array())
{ {
if($this->type == 'vfs-upload') if($this->type == 'vfs-upload' || $this->attrs['type'] == 'vfs-upload')
{ {
$form_name = self::form_name($cname, $this->id, $expand ? $expand : array('cont'=>self::$request->content)); $form_name = self::form_name($cname, $this->id, $expand ? $expand : array('cont'=>self::$request->content));
if($this->attrs['path'])
{
$path = $this->attrs['path'];
}
else
{
$path = $this->id;
}
$this->setElementAttribute($form_name, 'path', $path);
// ID maps to path - check there for any existing files // ID maps to path - check there for any existing files
list($app,$id,$relpath) = explode(':',$this->id,3); list($app,$id,$relpath) = explode(':',$path,3);
if($app && $id) if($app && $id)
{ {
if(!is_numeric($id)) if(!is_numeric($id))
@ -52,24 +61,44 @@ class etemplate_widget_vfs extends etemplate_widget_file
$path = egw_link::vfs_path($app,$id,'',true); $path = egw_link::vfs_path($app,$id,'',true);
if (!empty($relpath)) $path .= '/'.$relpath; if (!empty($relpath)) $path .= '/'.$relpath;
$value = array();
// Single file, already existing // Single file, already existing
if (substr($path,-1) != '/' && egw_vfs::file_exists($path) && !egw_vfs::is_dir($path)) if (substr($path,-1) != '/' && egw_vfs::file_exists($path) && !egw_vfs::is_dir($path))
{ {
$file = egw_vfs::stat($path); $file = egw_vfs::stat($path);
$file['path'] = egw_vfs::resolve_url($path); $file['path'] = $path;
$file['name'] = egw_vfs::basename($file['path']); $file['name'] = egw_vfs::basename($file['path']);
$file['mime'] = egw_vfs::mime_content_type($file['path']); $file['mime'] = egw_vfs::mime_content_type($file['path']);
$value = array($file); $value = array($file);
} }
// Single file, missing extension in path
else if (substr($path, -1) != '/' && !egw_vfs::file_exists($path) && $relpath && substr($relpath,-4,1) !== '.')
{
$find = egw_vfs::find(substr($path,0, - strlen($relpath)), array(
'type' => 'f',
'maxdepth' => 1,
'name' => $relpath . '*'
));
foreach($find as $file)
{
$file_info = egw_vfs::stat($file);
$file_info['path'] = $file;
$file_info['name'] = egw_vfs::basename($file_info['path']);
$file_info['mime'] = egw_vfs::mime_content_type($file_info['path']);
$value[] = $file_info;
}
}
else if (substr($path, -1) == '/' && egw_vfs::is_dir($path)) else if (substr($path, -1) == '/' && egw_vfs::is_dir($path))
{ {
$value = egw_vfs::scandir($path); $scan = egw_vfs::scandir($path);
foreach($value as &$file) foreach($scan as $file)
{ {
$file = egw_vfs::stat("$path$file"); $file_info = egw_vfs::stat("$path$file");
$file['path'] = $file['url']; $file_info['path'] = "$path$file";
$file['name'] = egw_vfs::basename($file['path']); $file_info['name'] = egw_vfs::basename($file_info['path']);
$file['mime'] = egw_vfs::mime_content_type($file['path']); $file_info['mime'] = egw_vfs::mime_content_type($file_info['path']);
$value[] = $file_info;
} }
} }
} }
@ -80,7 +109,7 @@ class etemplate_widget_vfs extends etemplate_widget_file
parent::ajax_upload(); parent::ajax_upload();
foreach($_FILES as $field => $file) foreach($_FILES as $field => $file)
{ {
self::store_file($_REQUEST['widget_id'], $file); self::store_file($_REQUEST['path'] ? $_REQUEST['path'] : $_REQUEST['widget_id'], $file);
} }
} }

View File

@ -575,6 +575,10 @@ var et2_customfields_list = et2_valueWidget.extend([et2_IDetachedDOM, et2_IInput
} }
}, },
_setup_link_entry: function(field_name, field, attrs) { _setup_link_entry: function(field_name, field, attrs) {
if(field.type === 'filemanager')
{
return this._setup_filemanager(field_name, field, attrs);
}
// No label on the widget itself // No label on the widget itself
delete(attrs.label); delete(attrs.label);
@ -583,6 +587,12 @@ var et2_customfields_list = et2_valueWidget.extend([et2_IDetachedDOM, et2_IInput
return true; return true;
}, },
_setup_filemanager: function(field_name, field, attrs) {
attrs.type = 'vfs-upload';
delete(attrs.label);
return true;
},
/** /**
* Set which fields are visible, by name * Set which fields are visible, by name
* *

View File

@ -395,9 +395,9 @@ var et2_file = et2_inputWidget.extend(
else else
{ {
// Wrong mime type - show in the list of files // Wrong mime type - show in the list of files
return self.createStatus( return this.createStatus(
self.egw().lang("File is of wrong type (%1 != %2)!", this.files[index].type, self.options.mime), this.egw().lang("File is of wrong type (%1 != %2)!", file.file.type, this.options.mime),
file_name file
); );
} }

View File

@ -645,6 +645,12 @@ var et2_vfsUpload = et2_file.extend(
attributes: { attributes: {
"value": { "value": {
"type": "any", // Either nothing, or an object with file info "type": "any", // Either nothing, or an object with file info
},
"path": {
"name": "Path",
"description": "Upload files to the specified VFS path",
"type": "string",
"default": ''
} }
}, },
legacyOptions: ["mime"], legacyOptions: ["mime"],
@ -664,8 +670,12 @@ var et2_vfsUpload = et2_file.extend(
this._super.apply(this, arguments); this._super.apply(this, arguments);
$j(this.node).addClass("et2_vfs"); $j(this.node).addClass("et2_vfs");
// If the ID is a directory, allow multiple uploads if(!this.options.path)
if(this.options.id.substr(-1) == '/') {
this.options.path = this.options.id;
}
// If the path is a directory, allow multiple uploads
if(this.options.path.substr(-1) == '/')
{ {
this.set_multiple(true); this.set_multiple(true);
} }
@ -674,16 +684,38 @@ var et2_vfsUpload = et2_file.extend(
/** /**
* If there is a file / files in the specified location, display them * If there is a file / files in the specified location, display them
* Value is the information for the file[s] in the specified location.
* *
* @param {Object[]} _value * @param {Object[]} _value
*/ */
set_value: function(_value) { set_value: function(_value) {
// Remove previous
while(this._children.length > 0)
{
var node = this._children[this._children.length-1];
this.removeChild(node);
node.free();
}
this.progress.empty(); this.progress.empty();
this.list.empty(); this.list.empty();
// Set new
if(typeof _value == 'object' && _value && _value.length)
{
for(var i = 0; i < _value.length; i++) for(var i = 0; i < _value.length; i++)
{ {
this._addFile(_value[i]); this._addFile(_value[i]);
} }
}
},
/**
* Value is determined by what's at the location specified by path
*
* @returns {null}
*/
getValue: function() {
return null;
}, },
getDOMNode: function(sender) { getDOMNode: function(sender) {
@ -706,9 +738,21 @@ var et2_vfsUpload = et2_file.extend(
} }
}, },
/**
* Add in the request id
*/
beforeSend: function(form)
{
var instance = this.getInstanceManager();
var extra = this._super.apply(this, arguments);
extra.path = this.options.path;
return extra;
},
_addFile: function(file_data) { _addFile: function(file_data) {
var row = $j(document.createElement("tr")) var row = $j(document.createElement("tr"))
.attr("data-path", file_data.url) .attr("data-path", file_data.path)
.attr("draggable", "true") .attr("draggable", "true")
.appendTo(this.list); .appendTo(this.list);
var mime = $j(document.createElement("td")) var mime = $j(document.createElement("td"))
@ -720,6 +764,40 @@ var et2_vfsUpload = et2_file.extend(
.appendTo(row); .appendTo(row);
var mime = et2_createWidget('vfs-mime',{value: file_data},this); var mime = et2_createWidget('vfs-mime',{value: file_data},this);
var vfs = et2_createWidget('vfs', {value: file_data}, this); var vfs = et2_createWidget('vfs', {value: file_data}, this);
// Add in delete button
if (!this.options.readonly)
{
var self = this;
var delete_button = $j(document.createElement("td"))
.appendTo(row);
$j("<div />")
.appendTo(delete_button)
// We don't use ui-icon because it assigns a bg image
.addClass("delete icon")
.bind( 'click', function() {
et2_dialog.show_dialog(
function(button) {
if(button == et2_dialog.YES_BUTTON)
{
egw.json("filemanager_ui::ajax_action", [
'delete',
[row.attr('data-path')],
''
],
function(data) {
if(data && data.errs == 0) {row.slideUp(row.remove);}
if(data && data.msg) {
self.egw().message(data.msg, data.errs == 0 ? 'success' : 'error');
}
}
).sendRequest();
}
},
egw.lang('Delete file?')
);
});
}
} }
}); });
et2_register_widget(et2_vfsUpload, ["vfs-upload"]); et2_register_widget(et2_vfsUpload, ["vfs-upload"]);

View File

@ -767,7 +767,7 @@ ul.et2_link_string {
.et2_link_list td.remark { .et2_link_list td.remark {
font-style: italic; font-style: italic;
} }
.et2_link_list td div.delete { .et2_link_list td div.delete, .et2_vfs td div.delete {
visibility: hidden; visibility: hidden;
background-image: url("images/close.png"); background-image: url("images/close.png");
background-position: center; background-position: center;
@ -775,12 +775,13 @@ ul.et2_link_string {
padding: 0px; padding: 0px;
} }
.et2_link_list .icon img, .et2_link_list .icon img,
.et2_link_list .icon { .et2_link_list .icon,
.et2_vfs .icon img, .et2_vfs .icon {
width: 16px; width: 16px;
height: 16px; height: 16px;
display: inline-block; display: inline-block;
} }
.et2_link_list tr:hover div.delete { .et2_link_list tr:hover div.delete, .et2_vfs tr:hover div.delete {
visibility: visible; visibility: visible;
} }
.egw_tooltip { .egw_tooltip {
@ -872,6 +873,7 @@ ul.et2_vfs {
} }
.et2_vfs td.icon { .et2_vfs td.icon {
width: 16px; width: 16px;
max-width: 16px;
} }
button.et2_vfs_btn { button.et2_vfs_btn {
margin: 0; margin: 0;