forked from extern/egroupware
Access dialog
- If current app has no special support, show general dialog instead of message - Sort apps in add dialog - Filter app list (filter2) to all apps for run rights, or only supporting apps otherwise
This commit is contained in:
parent
4479cf64c5
commit
91750f46c9
@ -248,6 +248,34 @@ class admin_acl
|
|||||||
}
|
}
|
||||||
//error_log(__METHOD__."(".array2string($query).") returning ".$total);
|
//error_log(__METHOD__."(".array2string($query).") returning ".$total);
|
||||||
|
|
||||||
|
// Get supporting or all apps for filter2 depending on filter
|
||||||
|
if($query['filter'] == 'run')
|
||||||
|
{
|
||||||
|
$rows['sel_options']['filter2'] = array(
|
||||||
|
'' => lang('All applications'),
|
||||||
|
)+etemplate_widget_menupopup::app_options('enabled');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$rows['sel_options']['filter2'] = array(
|
||||||
|
array('value' => '', 'label' => lang('All applications'))
|
||||||
|
);
|
||||||
|
$apps = $GLOBALS['egw']->hooks->process(array(
|
||||||
|
'location' => 'acl_rights',
|
||||||
|
'owner' => $query['account_id'],
|
||||||
|
), array(), true);
|
||||||
|
foreach($apps as $appname => $rights)
|
||||||
|
{
|
||||||
|
$rows['sel_options']['filter2'][] = array(
|
||||||
|
'value' => $appname,
|
||||||
|
'label' => lang($appname)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
usort($rows['sel_options']['filter2'], function($a,$b) {
|
||||||
|
return strcasecmp($a['label'], $b['label']);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
return $total;
|
return $total;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -388,10 +416,7 @@ class admin_acl
|
|||||||
'other' => lang('Access to %1 data by others', $user),
|
'other' => lang('Access to %1 data by others', $user),
|
||||||
'own' => lang('%1 access to other data', $user),
|
'own' => lang('%1 access to other data', $user),
|
||||||
'run' => lang('%1 run rights for applications', $user),
|
'run' => lang('%1 run rights for applications', $user),
|
||||||
),
|
)
|
||||||
'filter2' => array(
|
|
||||||
'' => lang('All applications'),
|
|
||||||
)+etemplate_widget_menupopup::app_options('enabled'),
|
|
||||||
);
|
);
|
||||||
|
|
||||||
$tpl->exec('admin.admin_acl.index', $content, $sel_options);
|
$tpl->exec('admin.admin_acl.index', $content, $sel_options);
|
||||||
|
@ -447,11 +447,17 @@ app.classes.admin = AppJS.extend(
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Restrict application selectbox to only apps that support ACL
|
// Restrict application selectbox to only apps that support ACL
|
||||||
sel_options.acl_appname = {};
|
sel_options.acl_appname = [];
|
||||||
for(var app in acl_rights)
|
for(var app in acl_rights)
|
||||||
{
|
{
|
||||||
sel_options.acl_appname[app] = this.egw.lang(app);
|
sel_options.acl_appname.push({value: app, label: this.egw.lang(app)});
|
||||||
}
|
}
|
||||||
|
// Sort list
|
||||||
|
sel_options.acl_appname.sort(function(a,b) {
|
||||||
|
if(a.label > b.label) return 1;
|
||||||
|
if(a.label < b.label) return -1;
|
||||||
|
return 0;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -116,7 +116,7 @@ egw.extend('preferences', egw.MODULE_GLOBAL, function() {
|
|||||||
var current_app = this.app_name();
|
var current_app = this.app_name();
|
||||||
var query = {current_app: current_app};
|
var query = {current_app: current_app};
|
||||||
// give warning, if app does not support given type, but all apps link to common prefs, if they dont support prefs themselfs
|
// give warning, if app does not support given type, but all apps link to common prefs, if they dont support prefs themselfs
|
||||||
if ($j.isArray(apps) && $j.inArray(current_app, apps) == -1 && name != 'prefs' ||
|
if ($j.isArray(apps) && $j.inArray(current_app, apps) == -1 && (name != 'prefs' && name != 'acl') ||
|
||||||
!$j.isArray(apps) && (typeof apps[current_app] == 'undefined' || !apps[current_app]))
|
!$j.isArray(apps) && (typeof apps[current_app] == 'undefined' || !apps[current_app]))
|
||||||
{
|
{
|
||||||
egw_message(egw.lang('Not supported by current application!'), 'warning');
|
egw_message(egw.lang('Not supported by current application!'), 'warning');
|
||||||
@ -134,7 +134,7 @@ egw.extend('preferences', egw.MODULE_GLOBAL, function() {
|
|||||||
|
|
||||||
case 'acl':
|
case 'acl':
|
||||||
query.menuaction='preferences.preferences_acl.index';
|
query.menuaction='preferences.preferences_acl.index';
|
||||||
query.acl_app=current_app;
|
if ($j.inArray(current_app, apps) != -1) query.acl_app=current_app;
|
||||||
egw.open_link(egw.link(url, query), '_blank', '900x450');
|
egw.open_link(egw.link(url, query), '_blank', '900x450');
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user