mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-12 17:08:16 +01:00
- Add 'Create directory' to context menu and placeholder actions
- Hide mail drop action when not allowed - Fix dropping in empty directory gave an error
This commit is contained in:
parent
3eb9f04221
commit
57f2e3c859
@ -144,6 +144,12 @@ class filemanager_ui
|
|||||||
'allowOnMultiple' => false,
|
'allowOnMultiple' => false,
|
||||||
'onExecute' => 'javaScript:app.filemanager.editprefs',
|
'onExecute' => 'javaScript:app.filemanager.editprefs',
|
||||||
),
|
),
|
||||||
|
'mkdir' => array(
|
||||||
|
'caption' => lang('Create directory'),
|
||||||
|
'group' => $group,
|
||||||
|
'allowOnMultiple' => false,
|
||||||
|
'onExecute' => 'javaScript:app.filemanager.createdir'
|
||||||
|
),
|
||||||
'mail' => array(
|
'mail' => array(
|
||||||
'caption' => lang('Mail files'),
|
'caption' => lang('Mail files'),
|
||||||
'icon' => 'filemanager/mail_post_to',
|
'icon' => 'filemanager/mail_post_to',
|
||||||
@ -176,7 +182,8 @@ class filemanager_ui
|
|||||||
'file_drop_mail' => array(
|
'file_drop_mail' => array(
|
||||||
'type' => 'drop',
|
'type' => 'drop',
|
||||||
'acceptedTypes' => 'mail',
|
'acceptedTypes' => 'mail',
|
||||||
'onExecute' => 'javaScript:app.filemanager.drop'
|
'onExecute' => 'javaScript:app.filemanager.drop',
|
||||||
|
'hideOnDisabled' => true
|
||||||
),
|
),
|
||||||
'file_drop_move' => array(
|
'file_drop_move' => array(
|
||||||
'icon' => 'stylite/move',
|
'icon' => 'stylite/move',
|
||||||
@ -282,7 +289,7 @@ class filemanager_ui
|
|||||||
'is_parent_value'=> egw_vfs::DIR_MIME_TYPE,
|
'is_parent_value'=> egw_vfs::DIR_MIME_TYPE,
|
||||||
'header_left' => 'filemanager.index.header_left',
|
'header_left' => 'filemanager.index.header_left',
|
||||||
'favorites' => true,
|
'favorites' => true,
|
||||||
'placeholder_actions' => array('file_drop_mail','file_drop_move','file_drop_copy','file_drop_symlink')
|
'placeholder_actions' => array('mkdir','file_drop_mail','file_drop_move','file_drop_copy','file_drop_symlink')
|
||||||
);
|
);
|
||||||
$content['nm']['path'] = static::get_home_dir();
|
$content['nm']['path'] = static::get_home_dir();
|
||||||
}
|
}
|
||||||
|
@ -433,14 +433,22 @@ app.classes.filemanager = AppJS.extend(
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Prompt user for directory to create
|
* Prompt user for directory to create
|
||||||
|
*
|
||||||
|
* @param {egwAction|undefined} action Action, or undefined if called directly
|
||||||
|
* @param {egwActionObject[] | undefined} selected Selected row, or undefined if called directly
|
||||||
*/
|
*/
|
||||||
createdir: function()
|
createdir: function(action, selected)
|
||||||
{
|
{
|
||||||
var dir = prompt(this.egw.lang('New directory'));
|
var dir = prompt(this.egw.lang('New directory'));
|
||||||
|
|
||||||
if (dir)
|
if (dir)
|
||||||
{
|
{
|
||||||
var path = this.get_path();
|
var path = this.get_path();
|
||||||
|
if(action)
|
||||||
|
{
|
||||||
|
var paths = this._elems2paths(selected);
|
||||||
|
if(paths[0]) path = paths[0];
|
||||||
|
}
|
||||||
this._do_action('createdir', dir, true); // true=synchronous request
|
this._do_action('createdir', dir, true); // true=synchronous request
|
||||||
this.change_dir((path == '/' ? '' : path)+'/'+dir);
|
this.change_dir((path == '/' ? '' : path)+'/'+dir);
|
||||||
}
|
}
|
||||||
@ -604,14 +612,23 @@ app.classes.filemanager = AppJS.extend(
|
|||||||
drop: function(_action, _elems, _target)
|
drop: function(_action, _elems, _target)
|
||||||
{
|
{
|
||||||
var src = this._elems2paths(_elems);
|
var src = this._elems2paths(_elems);
|
||||||
var dst = this.id2path(_target.id);
|
|
||||||
//alert(_action.id+': '+src.join(', ')+' --> '+dst);
|
|
||||||
|
|
||||||
// check if target is a file --> use it's directory instead
|
|
||||||
var data = egw.dataGetUIDdata(_target.id);
|
// Target will be missing ID if directory is empty
|
||||||
if (!data || data.data.mime != 'httpd/unix-directory')
|
// so start with the current directory
|
||||||
|
var dst = this.get_path();
|
||||||
|
|
||||||
|
// File(s) were dropped on a row, they want them inside
|
||||||
|
if(_target && _target.id)
|
||||||
{
|
{
|
||||||
dst = this.dirname(dst);
|
dst = this.id2path(_target.id);
|
||||||
|
|
||||||
|
// check if target is a file --> use it's directory instead
|
||||||
|
var data = egw.dataGetUIDdata(_target.id);
|
||||||
|
if (!data || data.data.mime != 'httpd/unix-directory')
|
||||||
|
{
|
||||||
|
dst = this.dirname(dst);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this._do_action(_action.id.replace("file_drop_",''), src, false, dst);
|
this._do_action(_action.id.replace("file_drop_",''), src, false, dst);
|
||||||
|
Loading…
Reference in New Issue
Block a user