Start of vfs widget

This commit is contained in:
Nathan Gray 2012-03-26 19:46:51 +00:00
parent 34a43e8869
commit e330a7bfdc
3 changed files with 134 additions and 0 deletions

View File

@ -0,0 +1,122 @@
/**
* eGroupWare eTemplate2 - JS VFS widgets
*
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @package etemplate
* @subpackage api
* @link http://www.egroupware.org
* @author Nathan Gray
* @copyright Nathan Gray 2012
* @version $Id$
*/
"use strict";
/*egw:uses
jquery.jquery;
et2_core_inputWidget;
et2_core_valueWidget;
*/
/**
* Class which implements the "vfs" XET-Tag
*/
var et2_vfs = et2_valueWidget.extend({
attributes: {
"value": {
"type": "any", // Object
"description": "Label of the button"
}
},
/**
* Mime type of directories
*/
DIR_MIME_TYPE: 'httpd/unix-directory',
init: function() {
this._super.apply(this, arguments);
this.value = "";
this.span = $j(document.createElement("ul"))
.addClass('et2_vfs');
this.setDOMNode(this.span[0]);
},
set_value: function(_value) {
var path = '';
if(_value.path)
{
path = _value.path
}
else if (typeof _value !== 'object')
{
this.egw().debug("warn", "%s only has path, needs full array", this.id);
this.span.empty().text(_value);
return;
}
var path_parts = path ? path.split('/') : [];
// TODO: This is apparently not used in old etemplate
//this._make_path(path_parts);
this._make_path([path_parts[path_parts.length-1]]);
// TODO: check perms
if(_value.mime && _value.mime == this.DIR_MIME_TYPE)
{
}
// Make it clickable
var data = {path: path, type: _value.mime}
jQuery("li",this.span).addClass("et2_clickable et2_link")
.click({data:data, egw: this.egw()}, function(e) {
e.data.egw.open(e.data.data, "file");
});
},
/**
* Create a list of clickable path components
*/
_make_path: function(path_parts) {
for(var i = 0; i < path_parts.length; i++)
{
var text = path_parts[i];
// Nice human-readable stuff for apps
if(path_parts[1] == 'apps')
{
switch(path_parts.length)
{
case 2:
if(i == 1)
{
text = this.egw().lang('applications');
}
break;
case 3:
if( i == 2)
{
text = this.egw().lang(path_parts[2]);
}
break;
case 4:
if(!isNaN(text))
{
text = this.egw().link_title(path_parts[2],path_parts[3]);
}
break;
}
}
path_parts[i] = text;
var part = $j(document.createElement("li"))
.addClass("vfsFilename")
.text(text)
.appendTo(this.span);
}
}
});
et2_register_widget(et2_vfs, ["vfs", "vfs-name", "vfs-size", "vfs-mode","vfs-mime","vfs-uid","vfs-gid"]);

View File

@ -37,6 +37,7 @@
et2_widget_progress; et2_widget_progress;
et2_widget_selectAccount; et2_widget_selectAccount;
et2_widget_ajaxSelect; et2_widget_ajaxSelect;
et2_widget_vfs;
et2_extension_nextmatch; et2_extension_nextmatch;
et2_extension_customfields; et2_extension_customfields;

View File

@ -448,6 +448,17 @@ ul.et2_link_string {
background-repeat: repeat-x; background-repeat: repeat-x;
} }
/**
* VFS widget(s)
*/
.et2_vfs li.vfsFilename {
display: inline;
margin-left: -30px;
}
.et2_vfs li.vfsFilename:not(:last-child):after {
content: '/';
padding: 0.25ex;
}
/** /**
* Validation * Validation