2010-01-31 00:57:03 +01:00
< ? php
/**
* EGgroupware admin - Edit global categories
*
* @ link http :// www . egroupware . org
* @ author Ralf Becker < RalfBecker - AT - outdoor - training . de >
* @ package admin
* @ copyright ( c ) 2010 by Ralf Becker < RalfBecker - AT - outdoor - training . de >
* @ license http :// opensource . org / licenses / gpl - license . php GPL - GNU General Public License
* @ version $Id $
*/
/**
* Edit global categories
*/
class admin_categories
{
/**
* Which methods of this class can be called as menuaction
*
* @ var array
*/
public $public_functions = array (
'index' => true ,
'edit' => true ,
);
/**
* Path where the icons are stored ( relative to webserver_url )
*/
const ICON_PATH = '/phpgwapi/images' ;
2011-02-15 13:51:21 +01:00
2011-06-16 00:27:40 +02:00
/**
* Flag used in the nextmatch filter to indicate filtering by user
*/
const FILTER_USER = '-user-' ;
2010-01-31 00:57:03 +01:00
/**
* Stupid old admin ACL - dont think anybody uses or understands it ; - )
2011-02-15 13:51:21 +01:00
*
2010-01-31 00:57:03 +01:00
* @ var boolean
*/
private static $acl_search ;
private static $acl_add ;
private static $acl_view ;
private static $acl_edit ;
private static $acl_delete ;
private static $acl_add_sub ;
/**
* Constructor
*/
function __construct ()
{
if ( ! isset ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'admin' ]))
{
throw new egw_exception_no_permission_admin ();
}
if ( $GLOBALS [ 'egw' ] -> acl -> check ( 'global_categories_access' , 1 , 'admin' ))
{
$GLOBALS [ 'egw' ] -> redirect_link ( '/index.php' );
}
self :: init_static ();
}
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
/**
* Init static vars ( static constructor )
*/
public static function init_static ()
{
if ( is_null ( self :: $acl_search ))
{
self :: $acl_search = ! $GLOBALS [ 'egw' ] -> acl -> check ( 'global_categories_access' , 2 , 'admin' );
self :: $acl_add = ! $GLOBALS [ 'egw' ] -> acl -> check ( 'global_categories_access' , 4 , 'admin' );
self :: $acl_view = ! $GLOBALS [ 'egw' ] -> acl -> check ( 'global_categories_access' , 8 , 'admin' );
self :: $acl_edit = ! $GLOBALS [ 'egw' ] -> acl -> check ( 'global_categories_access' , 16 , 'admin' );
self :: $acl_delete = ! $GLOBALS [ 'egw' ] -> acl -> check ( 'global_categories_access' , 32 , 'admin' );
self :: $acl_add_sub = ! $GLOBALS [ 'egw' ] -> acl -> check ( 'global_categories_access' , 64 , 'admin' );
}
}
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
/**
* Edit / add a category
2011-02-15 13:51:21 +01:00
*
2010-01-31 00:57:03 +01:00
* @ param array $content = null
* @ param string $msg = ''
*/
public function edit ( array $content = null , $msg = '' )
{
2010-04-13 13:45:22 +02:00
// read the session, as the global_cats param is stored with it.
$session = egw_cache :: getSession ( __CLASS__ , 'nm' );
$global_cats = $session [ 'global_cats' ];
unset ( $session );
2010-01-31 00:57:03 +01:00
if ( ! isset ( $content ))
{
2011-02-15 13:51:21 +01:00
if ( ! ( isset ( $_GET [ 'cat_id' ]) && $_GET [ 'cat_id' ] > 0 &&
2010-01-31 00:57:03 +01:00
( $content = categories :: read ( $_GET [ 'cat_id' ]))))
{
$content = array ( 'data' => array ());
if ( isset ( $_GET [ 'parent' ]) && $_GET [ 'parent' ] > 0 )
{
$content [ 'parent' ] = ( int ) $_GET [ 'parent' ];
}
if ( isset ( $_GET [ 'appname' ]) && isset ( $GLOBALS [ 'egw_info' ][ 'apps' ][ $_GET [ 'appname' ]]))
{
$content [ 'appname' ] = $_GET [ 'appname' ];
}
else
{
$content [ 'appname' ] = categories :: GLOBAL_APPNAME ;
}
}
elseif ( ! self :: $acl_edit )
{
// only allow to view category
$readonlys [ '__ALL__' ] = true ;
$readonlys [ 'button[cancel]' ] = false ;
}
$content [ 'base_url' ] = self :: icon_url ();
2010-01-31 04:28:32 +01:00
$content [ 'icon_url' ] = $content [ 'base_url' ] . $content [ 'data' ][ 'icon' ];
2010-01-31 00:57:03 +01:00
}
elseif ( $content [ 'button' ] || $content [ 'delete' ])
{
2010-01-31 04:36:01 +01:00
$cats = new categories ( $content [ 'owner' ] ? $content [ 'owner' ] : categories :: GLOBAL_ACCOUNT , $content [ 'appname' ]);
2010-01-31 00:57:03 +01:00
if ( $content [ 'delete' ][ 'delete' ])
{
$button = 'delete' ;
$delete_subs = $content [ 'delete' ][ 'subs' ];
}
else
{
list ( $button ) = each ( $content [ 'button' ]);
unset ( $content [ 'button' ]);
}
unset ( $content [ 'delete' ]);
switch ( $button )
{
case 'save' :
case 'apply' :
2011-06-16 17:51:42 +02:00
if ( $content [ 'owner' ] == '' ) $content [ 'owner' ] = 0 ;
2010-01-31 00:57:03 +01:00
if ( $content [ 'id' ] && self :: $acl_edit )
{
2010-10-14 17:33:10 +02:00
try {
$cats -> edit ( $content );
$msg = lang ( 'Category saved.' );
}
catch ( egw_exception_wrong_userinput $e )
{
$msg = lang ( 'Unwilling to save category with current settings. Check for inconsistency:' ) . $e -> getMessage (); // display conflicts etc.
}
2010-01-31 00:57:03 +01:00
}
elseif ( ! $content [ 'id' ] && (
$content [ 'parent' ] && self :: $acl_add_sub ||
! $content [ 'parent' ] && self :: $acl_add ))
{
$content [ 'id' ] = $cats -> add ( $content );
$msg = lang ( 'Category saved.' );
}
else
{
$msg = lang ( 'Permission denied!' );
unset ( $button );
}
break ;
case 'delete' :
if ( self :: $acl_delete )
{
$cats -> delete ( $content [ 'id' ], $delete_subs , ! $delete_subs );
$msg = lang ( 'Category deleted.' );
}
else
{
$msg = lang ( 'Permission denied!' );
unset ( $button );
}
break ;
}
$link = egw :: link ( '/index.php' , array (
'menuaction' => 'admin.admin_categories.index' ,
'msg' => $msg ,
2010-04-13 13:45:22 +02:00
'global_cats' => ( empty ( $global_cats ) ? false : true ),
2010-01-31 00:57:03 +01:00
));
$js = " window.opener.location=' $link '; " ;
if ( $button == 'save' || $button == 'delete' )
{
echo " <html><head><script> \n $js ; \n window.close(); \n </script></head></html> \n " ;
common :: egw_exit ();
}
if ( ! empty ( $js )) $GLOBALS [ 'egw' ] -> js -> set_onload ( $js );
}
$content [ 'msg' ] = $msg ;
$sel_options [ 'icon' ] = self :: get_icons ();
2011-06-16 00:27:40 +02:00
2011-06-14 20:50:35 +02:00
$sel_options [ 'owner' ] = array ( 0 => lang ( 'All users' ));
2011-06-16 00:27:40 +02:00
// User's category - add current value to be able to preserve owner
2011-06-16 17:51:42 +02:00
if ( ! $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'admin' ]) {
if ( $content [ 'owner' ] > 0 ) $sel_options [ 'owner' ][ $content [ 'owner' ]] = common :: grab_owner_name ( $content [ 'owner' ]);
}
else
2011-06-14 20:50:35 +02:00
{
2011-06-16 17:51:42 +02:00
$accs = $GLOBALS [ 'egw' ] -> accounts -> get_list ( 'groups' );
foreach ( $accs as $acc )
2011-06-14 20:50:35 +02:00
{
2011-06-16 17:51:42 +02:00
if ( $acc [ 'account_type' ] == 'g' )
{
$sel_options [ 'owner' ][ $acc [ 'account_id' ]] = ExecMethod2 ( 'etemplate.select_widget.accountInfo' , $acc [ 'account_id' ], $acc , $type2 , $type == 'both' );
}
2011-06-14 20:50:35 +02:00
}
}
egw_framework :: validate_file ( '.' , 'global_categories' , 'admin' );
egw_framework :: set_onload ( ' $ ( document ) . ready ( function () {
cat_original_owner = [ ' . ($content[' owner '] ? $content[' owner '] : ' 0 ') .' ];
permission_prompt = \ '' . lang ( 'cat_permission_confirm' ) . ' \ ' ;
}); ' );
2010-01-31 00:57:03 +01:00
$readonlys [ 'button[delete]' ] = ! $content [ 'id' ] || ! self :: $acl_delete ; // cant delete not yet saved category
$tmpl = new etemplate ( 'admin.categories.edit' );
$tmpl -> exec ( 'admin.admin_categories.edit' , $content , $sel_options , $readonlys , $content + array (
'old_parent' => $content [ 'old_parent' ] ? $content [ 'old_parent' ] : $content [ 'parent' ],
), 2 );
}
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
/**
* Return URL of an icon , or base url with trailing slash
2011-02-15 13:51:21 +01:00
*
2010-01-31 00:57:03 +01:00
* @ param string $icon = '' filename
* @ return string url
*/
static function icon_url ( $icon = '' )
{
return $GLOBALS [ 'egw_info' ][ 'server' ][ 'webserver_url' ] . self :: ICON_PATH . '/' . $icon ;
}
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
/**
* Return icons from / phpgwapi / images
2011-02-15 13:51:21 +01:00
*
2010-01-31 00:57:03 +01:00
* @ return array filename => label
*/
static function get_icons ()
{
$dir = dir ( EGW_SERVER_ROOT . self :: ICON_PATH );
$icons = array ();
while (( $file = $dir -> read ()))
{
if ( preg_match ( '/^(.*)\\.(png|gif|jpe?g)$/i' , $file , $matches ))
{
$icons [ $file ] = ucfirst ( $matches [ 1 ]);
}
}
$dir -> close ();
asort ( $icons );
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
return $icons ;
}
/**
* query rows for the nextmatch widget
*
* @ param array $query with keys 'start' , 'search' , 'order' , 'sort' , 'col_filter'
* @ param array & $rows returned rows / competitions
* @ param array & $readonlys eg . to disable buttons based on acl , not use here , maybe in a derived class
* @ return int total number of rows
*/
static function get_rows ( $query , & $rows , & $readonlys )
{
self :: init_static ();
if ( ! isset ( $query [ 'appname' ]))
{
throw new egw_exception_assertion_failed ( __METHOD__ . '($query,...) $query[appname] NOT set!' );
}
2011-06-16 00:27:40 +02:00
$globalcat = ( $query [ 'filter' ] == categories :: GLOBAL_ACCOUNT );
2010-04-13 12:29:05 +02:00
if ( isset ( $query [ 'global_cats' ]) && $query [ 'global_cats' ] === false )
{
$globalcat = false ;
}
2010-01-31 00:57:03 +01:00
egw_cache :: setSession ( __CLASS__ , 'nm' , $query );
2011-06-16 00:27:40 +02:00
if ( $query [ 'filter' ])
{
$filter [ 'owner' ] = $query [ 'filter' ] == self :: FILTER_USER ? $query [ 'col_filter' ][ 'owner' ] : $query [ 'filter' ];
}
$cats = new categories ( $query [ 'filter' ] == self :: FILTER_USER ? $query [ 'col_filter' ][ 'owner' ] : $query [ 'filter' ], $query [ 'appname' ]);
// Use all parents, in case user has their cat as a child of a global or something
$parent = array ( 0 );
if ( $query [ 'filter' ]) $parent += $cats -> return_array ( 'all' , 0 , false , '' , 'ASC' , '' , true , $parent , - 1 , 'id' );
$rows = $cats -> return_sorted_array ( $query [ 'start' ], $query [ 'num_rows' ], $query [ 'search' ], $query [ 'sort' ], $query [ 'order' ], $globalcat , $parent , true , $filter );
2010-01-31 00:57:03 +01:00
foreach ( $rows as & $row )
{
$row [ 'level_spacer' ] = str_repeat ( ' ' , $row [ 'level' ]);
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
if ( $row [ 'data' ][ 'icon' ]) $row [ 'icon_url' ] = self :: icon_url ( $row [ 'data' ][ 'icon' ]);
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
$row [ 'subs' ] = count ( $row [ 'children' ]);
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
$row [ 'class' ] = 'level' . $row [ 'level' ];
2011-02-15 13:51:21 +01:00
2010-01-31 00:57:03 +01:00
$readonlys [ " edit[ $row[id] ] " ] = ! self :: $acl_edit ;
$readonlys [ " add[ $row[id] ] " ] = ! self :: $acl_add_sub ;
$readonlys [ " delete[ $row[id] ] " ] = ! self :: $acl_delete ;
}
// make appname available for actions
$rows [ 'appname' ] = $query [ 'appname' ];
$GLOBALS [ 'egw_info' ][ 'flags' ][ 'app_header' ] = lang ( 'Admin' ) . ' - ' . lang ( 'Global categories' ) .
( $query [ 'appname' ] != categories :: GLOBAL_APPNAME ? ': ' . lang ( $query [ 'appname' ]) : '' );
return $cats -> total_records ;
}
/**
* Display the accesslog
*
* @ param array $content = null
* @ param string $msg = ''
*/
public function index ( array $content = null , $msg = '' )
{
2010-04-13 12:29:05 +02:00
//_debug_array($_GET);
2010-01-31 00:57:03 +01:00
if ( ! isset ( $content ))
{
if ( isset ( $_GET [ 'msg' ])) $msg = $_GET [ 'msg' ];
2011-06-16 00:27:40 +02:00
$appname = $content [ 'nm' ][ 'appname' ] ? $content [ 'nm' ][ 'appname' ] : categories :: GLOBAL_APPNAME ;
2010-01-31 00:57:03 +01:00
$content [ 'nm' ] = egw_cache :: getSession ( __CLASS__ , 'nm' );
2010-01-31 04:28:32 +01:00
if ( ! is_array ( $content [ 'nm' ]))
2010-01-31 00:57:03 +01:00
{
$content [ 'nm' ] = array (
'get_rows' => 'admin_categories::get_rows' , // I method/callback to request the data for the rows eg. 'notes.bo.get_rows'
2011-06-16 00:27:40 +02:00
'no_filter' => false ,
'filter' => categories :: GLOBAL_ACCOUNT ,
'options-filter' => array (
'' => lang ( 'All categories' ),
categories :: GLOBAL_ACCOUNT => lang ( 'Global categories' ),
$GLOBALS [ 'egw_info' ][ 'user' ][ 'account_id' ] => lang ( 'Own categories' ),
),
2010-01-31 00:57:03 +01:00
'no_filter2' => True , // I disable the 2. filter (params are the same as for filter)
'no_cat' => True , // I disable the cat-selectbox
'header_left' => false , // I template to show left of the range-value, left-aligned (optional)
'header_right' => false , // I template to show right of the range-value, right-aligned (optional)
'never_hide' => True , // I never hide the nextmatch-line if less then maxmatch entries
'lettersearch' => false , // I show a lettersearch
'start' => 0 , // IO position in list
'order' => 'name' , // IO name of the column to sort after (optional for the sortheaders)
'sort' => 'ASC' , // IO direction of the sort: 'ASC' or 'DESC'
'default_cols' => '!color,last_mod,subs' , // I columns to use if there's no user or default pref (! as first char uses all but the named columns), default all columns
'csv_fields' => false , // I false=disable csv export, true or unset=enable it with auto-detected fieldnames,
//or array with name=>label or name=>array('label'=>label,'type'=>type) pairs (type is a eT widget-type)
2011-06-16 00:27:40 +02:00
'appname' => $appname ,
2010-01-31 00:57:03 +01:00
'no_search' => ! self :: $acl_search ,
);
}
2010-04-13 13:45:22 +02:00
else
{
$content [ 'nm' ][ 'start' ] = 0 ;
}
2010-01-31 00:57:03 +01:00
if ( isset ( $_GET [ 'appname' ]) && ( $_GET [ 'appname' ] == categories :: GLOBAL_APPNAME ||
isset ( $GLOBALS [ 'egw_info' ][ 'apps' ][ $_GET [ 'appname' ]])))
{
$content [ 'nm' ][ 'appname' ] = $_GET [ 'appname' ];
}
2010-04-13 13:45:22 +02:00
$content [ 'nm' ][ 'global_cats' ] = true ;
2010-04-13 12:29:05 +02:00
if ( isset ( $_GET [ 'global_cats' ]) && empty ( $_GET [ 'global_cats' ] ))
{
$content [ 'nm' ][ 'global_cats' ] = false ;
}
2010-01-31 00:57:03 +01:00
}
else
{
2011-02-15 13:51:21 +01:00
if ( $content [ 'delete' ][ 'delete' ] && ( $cat = categories :: read ( $content [ 'delete' ][ 'cat_id' ])))
2010-01-31 00:57:03 +01:00
{
2011-02-15 13:51:21 +01:00
$cats = new categories ( categories :: GLOBAL_ACCOUNT , $cat [ 'appname' ]);
2010-01-31 00:57:03 +01:00
$cats -> delete ( $content [ 'delete' ][ 'cat_id' ], $content [ 'delete' ][ 'subs' ], ! $content [ 'delete' ][ 'subs' ]);
$msg = lang ( 'Category deleted.' );
}
unset ( $content [ 'delete' ]);
}
$content [ 'msg' ] = $msg ;
2010-01-31 04:28:32 +01:00
$readonlys [ 'add' ] = ! self :: $acl_add ;
2011-06-16 00:27:40 +02:00
if ( $GLOBALS [ 'egw_info' ][ 'user' ][ 'apps' ][ 'admin' ])
{
$content [ 'nm' ][ 'options-filter' ][ self :: FILTER_USER ] = lang ( 'Limit to user' );
} else {
$readonlys [ 'nm' ][ 'rows' ][ 'owner' ] = true ;
}
2010-01-31 00:57:03 +01:00
$tmpl = new etemplate ( 'admin.categories.index' );
$tmpl -> exec ( 'admin.admin_categories.index' , $content , $sel_options , $readonlys , array (
'nm' => $content [ 'nm' ],
));
}
}
admin_categories :: init_static ();