mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-11 16:38:52 +01:00
fixed not working refresh of user category list called via top-menu after adding/editing a category
This commit is contained in:
parent
5b2c568eb5
commit
3093cb6b85
@ -5,7 +5,7 @@
|
|||||||
* @link http://www.egroupware.org
|
* @link http://www.egroupware.org
|
||||||
* @author Ralf Becker <RalfBecker-AT-outdoor-training.de>
|
* @author Ralf Becker <RalfBecker-AT-outdoor-training.de>
|
||||||
* @package admin
|
* @package admin
|
||||||
* @copyright (c) 2010 by Ralf Becker <RalfBecker-AT-outdoor-training.de>
|
* @copyright (c) 2010-14 by Ralf Becker <RalfBecker-AT-outdoor-training.de>
|
||||||
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
*/
|
*/
|
||||||
@ -91,7 +91,6 @@ class admin_categories
|
|||||||
// read the session, as the global_cats param is stored with it.
|
// read the session, as the global_cats param is stored with it.
|
||||||
$appname = $content['appname'] ? $content['appname'] : ($_GET['appname']?$_GET['appname']:categories::GLOBAL_APPNAME);
|
$appname = $content['appname'] ? $content['appname'] : ($_GET['appname']?$_GET['appname']:categories::GLOBAL_APPNAME);
|
||||||
$session = egw_cache::getSession(__CLASS__.$appname,'nm');
|
$session = egw_cache::getSession(__CLASS__.$appname,'nm');
|
||||||
$global_cats = $session['global_cats'];
|
|
||||||
unset($session);
|
unset($session);
|
||||||
if (!isset($content))
|
if (!isset($content))
|
||||||
{
|
{
|
||||||
@ -139,6 +138,8 @@ class admin_categories
|
|||||||
}
|
}
|
||||||
unset($content['delete']);
|
unset($content['delete']);
|
||||||
|
|
||||||
|
$refresh_app = $this->appname == 'preferences' ? $content['appname'] : $this->appname;
|
||||||
|
|
||||||
switch($button)
|
switch($button)
|
||||||
{
|
{
|
||||||
case 'save':
|
case 'save':
|
||||||
@ -152,7 +153,7 @@ class admin_categories
|
|||||||
// to reload the whole nextmatch instead of just the row
|
// to reload the whole nextmatch instead of just the row
|
||||||
$data = $cats->id2name($content['id'],'data');
|
$data = $cats->id2name($content['id'],'data');
|
||||||
$change_color = ($data['color'] != $content['data']['color']);
|
$change_color = ($data['color'] != $content['data']['color']);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$cats->edit($content);
|
$cats->edit($content);
|
||||||
$msg = lang('Category saved.');
|
$msg = lang('Category saved.');
|
||||||
@ -176,7 +177,7 @@ class admin_categories
|
|||||||
}
|
}
|
||||||
if ($button == 'save')
|
if ($button == 'save')
|
||||||
{
|
{
|
||||||
egw_framework::refresh_opener($msg, 'admin', $content['id'], $change_color ? 'edit' : 'update');
|
egw_framework::refresh_opener($msg, $refresh_app, $content['id'], $change_color ? 'edit' : 'update', 'admin');
|
||||||
egw_framework::window_close();
|
egw_framework::window_close();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -187,7 +188,7 @@ class admin_categories
|
|||||||
$cats->delete($content['id'],$delete_subs,!$delete_subs);
|
$cats->delete($content['id'],$delete_subs,!$delete_subs);
|
||||||
$msg = lang('Category deleted.');
|
$msg = lang('Category deleted.');
|
||||||
// Refresh internally looks for template name, which starts with 'admin'
|
// Refresh internally looks for template name, which starts with 'admin'
|
||||||
egw_framework::refresh_opener($msg, 'admin', $content['id'],'delete');
|
egw_framework::refresh_opener($msg, $refresh_app, $content['id'],'delete', 'admin');
|
||||||
egw_framework::window_close();
|
egw_framework::window_close();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -199,7 +200,7 @@ class admin_categories
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// Refresh internally looks for template name, which starts with 'admin'
|
// Refresh internally looks for template name, which starts with 'admin'
|
||||||
egw_framework::refresh_opener($msg, 'admin', $content['id'], $change_color ? 'edit' : 'update');
|
egw_framework::refresh_opener($msg, $refresh_app, $content['id'], $change_color ? 'edit' : 'update', 'admin');
|
||||||
}
|
}
|
||||||
$content['msg'] = $msg;
|
$content['msg'] = $msg;
|
||||||
if(!$content['appname']) $content['appname'] = $appname;
|
if(!$content['appname']) $content['appname'] = $appname;
|
||||||
@ -246,7 +247,7 @@ class admin_categories
|
|||||||
{
|
{
|
||||||
if ($acc['account_type'] == 'g')
|
if ($acc['account_type'] == 'g')
|
||||||
{
|
{
|
||||||
$sel_options['owner'][$acc['account_id']] = ExecMethod2('etemplate.select_widget.accountInfo',$acc['account_id'],$acc,$type2,$type=='both');
|
$sel_options['owner'][$acc['account_id']] = ExecMethod2('etemplate.select_widget.accountInfo',$acc['account_id'],$acc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$content['no_private'] = true;
|
$content['no_private'] = true;
|
||||||
@ -264,7 +265,7 @@ class admin_categories
|
|||||||
}
|
}
|
||||||
|
|
||||||
egw_framework::validate_file('.','global_categories','admin');
|
egw_framework::validate_file('.','global_categories','admin');
|
||||||
|
|
||||||
$readonlys['button[delete]'] = !$content['id'] || !self::$acl_delete || // cant delete not yet saved category
|
$readonlys['button[delete]'] = !$content['id'] || !self::$acl_delete || // cant delete not yet saved category
|
||||||
$appname != $content['appname'] || // Can't edit a category from a different app
|
$appname != $content['appname'] || // Can't edit a category from a different app
|
||||||
($this->appname != 'admin' && $content['owner'] != $GLOBALS['egw_info']['user']['account_id']);
|
($this->appname != 'admin' && $content['owner'] != $GLOBALS['egw_info']['user']['account_id']);
|
||||||
@ -296,6 +297,7 @@ class admin_categories
|
|||||||
{
|
{
|
||||||
$dir = dir(EGW_SERVER_ROOT.self::ICON_PATH);
|
$dir = dir(EGW_SERVER_ROOT.self::ICON_PATH);
|
||||||
$icons = array();
|
$icons = array();
|
||||||
|
$matches = null;
|
||||||
while(($file = $dir->read()))
|
while(($file = $dir->read()))
|
||||||
{
|
{
|
||||||
if (preg_match('/^(.*)\\.(png|gif|jpe?g)$/i',$file,$matches))
|
if (preg_match('/^(.*)\\.(png|gif|jpe?g)$/i',$file,$matches))
|
||||||
@ -341,11 +343,10 @@ class admin_categories
|
|||||||
{
|
{
|
||||||
$filter['appname'] = $query['col_filter']['app'];
|
$filter['appname'] = $query['col_filter']['app'];
|
||||||
}
|
}
|
||||||
$old_cats = $GLOBALS['egw']->categories;
|
|
||||||
$GLOBALS['egw']->categories = $cats = new categories($filter['owner'],$query['appname']);
|
$GLOBALS['egw']->categories = $cats = new categories($filter['owner'],$query['appname']);
|
||||||
$globalcat = isset($GLOBALS['egw_info']['user']['apps']['admin']) ? 'all_no_acl' : $globalcat; // ignore acl only for admins
|
$globals = isset($GLOBALS['egw_info']['user']['apps']['admin']) ? 'all_no_acl' : $globalcat; // ignore acl only for admins
|
||||||
$parent = $query['search'] ? false : 0;
|
$parent = $query['search'] ? false : 0;
|
||||||
$rows = $cats->return_sorted_array($query['start'],false,$query['search'],$query['sort'],$query['order'],$globalcat,$parent,true,$filter);
|
$rows = $cats->return_sorted_array($query['start'],false,$query['search'],$query['sort'],$query['order'],$globals,$parent,true,$filter);
|
||||||
$count = $cats->total_records;
|
$count = $cats->total_records;
|
||||||
foreach($rows as $key => &$row)
|
foreach($rows as $key => &$row)
|
||||||
{
|
{
|
||||||
@ -377,7 +378,7 @@ class admin_categories
|
|||||||
$readonlys["add[$row[id]]"] = !self::$acl_add_sub;
|
$readonlys["add[$row[id]]"] = !self::$acl_add_sub;
|
||||||
$readonlys["delete[$row[id]]"] = !self::$acl_delete;
|
$readonlys["delete[$row[id]]"] = !self::$acl_delete;
|
||||||
}
|
}
|
||||||
$rows = $count <= $query['num_rows'] ? array_values($rows) : array_slice($rows, $query['start'], $query['num_rows']);
|
if (true) $rows = $count <= $query['num_rows'] ? array_values($rows) : array_slice($rows, $query['start'], $query['num_rows']);
|
||||||
// make appname available for actions
|
// make appname available for actions
|
||||||
$rows['appname'] = $query['appname'];
|
$rows['appname'] = $query['appname'];
|
||||||
$rows['edit_link'] = $this->edit_link;
|
$rows['edit_link'] = $this->edit_link;
|
||||||
@ -503,8 +504,10 @@ class admin_categories
|
|||||||
}
|
}
|
||||||
$content['nm']['action'] .= '_' . $content[$action];
|
$content['nm']['action'] .= '_' . $content[$action];
|
||||||
}
|
}
|
||||||
|
$success = $failed = 0;
|
||||||
|
$action_msg = null;
|
||||||
if ($this->action($content['nm']['action'],$content['nm']['selected'],$content['nm']['select_all'],
|
if ($this->action($content['nm']['action'],$content['nm']['selected'],$content['nm']['select_all'],
|
||||||
$success,$failed,$action_msg,$content['nm'],$msg))
|
$success,$failed,$action_msg,$content['nm']))
|
||||||
{
|
{
|
||||||
$msg .= lang('%1 category(s) %2',$success,$action_msg);
|
$msg .= lang('%1 category(s) %2',$success,$action_msg);
|
||||||
}
|
}
|
||||||
@ -528,14 +531,14 @@ class admin_categories
|
|||||||
'public' => 'No',
|
'public' => 'No',
|
||||||
'private' => 'Yes',
|
'private' => 'Yes',
|
||||||
);
|
);
|
||||||
|
|
||||||
$sel_options['owner'][0] = lang('All users');
|
$sel_options['owner'][0] = lang('All users');
|
||||||
$accs = $GLOBALS['egw']->accounts->get_list('groups');
|
$accs = $GLOBALS['egw']->accounts->get_list('groups');
|
||||||
foreach($accs as $acc)
|
foreach($accs as $acc)
|
||||||
{
|
{
|
||||||
if ($acc['account_type'] == 'g')
|
if ($acc['account_type'] == 'g')
|
||||||
{
|
{
|
||||||
$sel_options['owner'][$acc['account_id']] = ExecMethod2('etemplate.select_widget.accountInfo',$acc['account_id'],$acc,$type2,$type=='both');
|
$sel_options['owner'][$acc['account_id']] = ExecMethod2('etemplate.select_widget.accountInfo',$acc['account_id'],$acc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -618,19 +621,16 @@ class admin_categories
|
|||||||
/**
|
/**
|
||||||
* Handles actions on multiple entries
|
* Handles actions on multiple entries
|
||||||
*
|
*
|
||||||
* @param action
|
* @param string $_action
|
||||||
* @param array $checked contact id's to use if !$use_all
|
* @param array $checked contact id's to use if !$use_all
|
||||||
* @param boolean $use_all if true use all entries of the current selection (in the session)
|
* @param boolean $use_all if true use all entries of the current selection (in the session)
|
||||||
* @param int &$success number of succeded actions
|
* @param int &$success number of succeded actions
|
||||||
* @param int &$failed number of failed actions (not enought permissions)
|
* @param int &$failed number of failed actions (not enought permissions)
|
||||||
* @param string &$action_msg translated verb for the actions, to be used in a message like '%1 entries deleted'
|
* @param string &$action_msg translated verb for the actions, to be used in a message like '%1 entries deleted'
|
||||||
* @param array $query get_rows parameter
|
* @param array $query get_rows parameter
|
||||||
* @param string &$msg on return user feedback
|
|
||||||
* @param boolean $skip_notifications = false true to NOT notify users about changes
|
|
||||||
* @return boolean true if all actions succeded, false otherwise
|
* @return boolean true if all actions succeded, false otherwise
|
||||||
*/
|
*/
|
||||||
function action($action, $checked, $use_all, &$success, &$failed, &$action_msg,
|
function action($_action, $checked, $use_all, &$success, &$failed, &$action_msg, array $query)
|
||||||
array $query, &$msg, $skip_notifications = false)
|
|
||||||
{
|
{
|
||||||
//echo '<p>'.__METHOD__."('$action',".array2string($checked).','.(int)$use_all.",...)</p>\n";
|
//echo '<p>'.__METHOD__."('$action',".array2string($checked).','.(int)$use_all.",...)</p>\n";
|
||||||
$success = $failed = 0;
|
$success = $failed = 0;
|
||||||
@ -638,6 +638,7 @@ class admin_categories
|
|||||||
{
|
{
|
||||||
@set_time_limit(0); // switch off the execution time limit, as it's for big selections to small
|
@set_time_limit(0); // switch off the execution time limit, as it's for big selections to small
|
||||||
$query['num_rows'] = -1; // all
|
$query['num_rows'] = -1; // all
|
||||||
|
$result = $readonlys = array();
|
||||||
$this->get_rows($query,$result,$readonlys);
|
$this->get_rows($query,$result,$readonlys);
|
||||||
$checked = array();
|
$checked = array();
|
||||||
foreach($result as $key => $info)
|
foreach($result as $key => $info)
|
||||||
@ -652,7 +653,7 @@ class admin_categories
|
|||||||
$app = $query['col_filter']['app'] ? $query['col_filter']['app'] : $query['appname'];
|
$app = $query['col_filter']['app'] ? $query['col_filter']['app'] : $query['appname'];
|
||||||
$cats = new categories($owner,$app);
|
$cats = new categories($owner,$app);
|
||||||
|
|
||||||
list($action, $settings) = explode('_', $action, 2);
|
list($action, $settings) = explode('_', $_action, 2);
|
||||||
|
|
||||||
switch($action)
|
switch($action)
|
||||||
{
|
{
|
||||||
@ -666,8 +667,8 @@ class admin_categories
|
|||||||
break;
|
break;
|
||||||
case 'owner':
|
case 'owner':
|
||||||
$action_msg = lang('updated');
|
$action_msg = lang('updated');
|
||||||
list($add_remove, $ids) = explode('_', $settings, 2);
|
list($add_remove, $ids_csv) = explode('_', $settings, 2);
|
||||||
$ids = explode(',',$ids);
|
$ids = explode(',', $ids_csv);
|
||||||
// Adding 'All users' removes all the others
|
// Adding 'All users' removes all the others
|
||||||
if($add_remove == 'add' && array_search(categories::GLOBAL_ACCOUNT,$ids) !== false) $ids = array(categories::GLOBAL_ACCOUNT);
|
if($add_remove == 'add' && array_search(categories::GLOBAL_ACCOUNT,$ids) !== false) $ids = array(categories::GLOBAL_ACCOUNT);
|
||||||
|
|
||||||
|
@ -255,14 +255,14 @@ egw.extend('message', egw.MODULE_WND_LOCAL, function(_app, _wnd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// etemplate2 specific to avoid reloading whole page
|
// etemplate2 specific to avoid reloading whole page
|
||||||
if(typeof etemplate2 != "undefined" && etemplate2.app_refresh)
|
if(typeof win.etemplate2 != "undefined" && win.etemplate2.app_refresh)
|
||||||
{
|
{
|
||||||
var refresh_done = etemplate2.app_refresh(_msg, _app, _id, _type);
|
var refresh_done = win.etemplate2.app_refresh(_msg, _app, _id, _type);
|
||||||
|
|
||||||
// Refresh target or current app too
|
// Refresh target or current app too
|
||||||
if ((_targetapp || this.app_name()) != _app)
|
if ((_targetapp || this.app_name()) != _app)
|
||||||
{
|
{
|
||||||
refresh_done = etemplate2.app_refresh(_msg, _targetapp || this.app_name()) || refresh_done;
|
refresh_done = win.etemplate2.app_refresh(_msg, _targetapp || this.app_name()) || refresh_done;
|
||||||
}
|
}
|
||||||
//In case that we have etemplate2 ready but it's empty and refresh is not done
|
//In case that we have etemplate2 ready but it's empty and refresh is not done
|
||||||
if (refresh_done) return;
|
if (refresh_done) return;
|
||||||
|
Loading…
Reference in New Issue
Block a user