mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-12 08:58:25 +01:00
prototype for an admin app using et2 and a navigation tree, need to set index url in database: UPDATE egw_applications SET app_index="admin.admin_ui.index&ajax=true" WHERE app_name="admin" (dont forget to clear cache)
This commit is contained in:
parent
bca1712229
commit
ffceaf445a
@ -31,6 +31,8 @@ class admin_prefs_sidebox_hooks
|
|||||||
*/
|
*/
|
||||||
static function all_hooks($args)
|
static function all_hooks($args)
|
||||||
{
|
{
|
||||||
|
unset($GLOBALS['egw_info']['user']['preferences']['common']['auto_hide_sidebox']);
|
||||||
|
|
||||||
if (!isset($_GET['menuaction']) && substr($_SERVER['PHP_SELF'],-16) == '/admin/index.php')
|
if (!isset($_GET['menuaction']) && substr($_SERVER['PHP_SELF'],-16) == '/admin/index.php')
|
||||||
{
|
{
|
||||||
admin_statistics::check();
|
admin_statistics::check();
|
||||||
@ -38,9 +40,21 @@ class admin_prefs_sidebox_hooks
|
|||||||
$appname = 'admin';
|
$appname = 'admin';
|
||||||
$location = is_array($args) ? $args['location'] : $args;
|
$location = is_array($args) ? $args['location'] : $args;
|
||||||
|
|
||||||
|
if ($location == 'sidebox_menu')
|
||||||
|
{
|
||||||
|
// Destination div for folder tree
|
||||||
|
$file[] = array(
|
||||||
|
'no_lang' => true,
|
||||||
|
'text' => '<span id="admin_tree_target" class="admin_tree" />',
|
||||||
|
'link' => false,
|
||||||
|
'icon' => false
|
||||||
|
);
|
||||||
|
display_sidebox($appname,lang('Admin'),$file);
|
||||||
|
return;
|
||||||
|
}
|
||||||
if ($GLOBALS['egw_info']['user']['apps']['admin'] && $location != 'admins')
|
if ($GLOBALS['egw_info']['user']['apps']['admin'] && $location != 'admins')
|
||||||
{
|
{
|
||||||
$file['new admin'] = egw::link('/index.php', array('menuaction' => 'admin.admin_ui.index'));
|
|
||||||
if (! $GLOBALS['egw']->acl->check('site_config_access',1,'admin'))
|
if (! $GLOBALS['egw']->acl->check('site_config_access',1,'admin'))
|
||||||
{
|
{
|
||||||
$file['Site Configuration'] = egw::link('/index.php','menuaction=admin.uiconfig.index&appname=admin');
|
$file['Site Configuration'] = egw::link('/index.php','menuaction=admin.uiconfig.index&appname=admin');
|
||||||
@ -136,7 +150,7 @@ $file['new admin'] = egw::link('/index.php', array('menuaction' => 'admin.admin_
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
foreach($file as &$url) if (is_array($url)) $url = $url['link'];
|
foreach($file as &$url) if (is_array($url) && $url['link']) $url = $url['link'];
|
||||||
display_sidebox($appname,lang('Admin'),$file);
|
display_sidebox($appname,lang('Admin'),$file);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -33,10 +33,10 @@ class admin_ui
|
|||||||
*/
|
*/
|
||||||
public function index(array $content=null, $msg='')
|
public function index(array $content=null, $msg='')
|
||||||
{
|
{
|
||||||
$tpl = new etemplate('admin.index');
|
$tpl = new etemplate_new('admin.index');
|
||||||
|
|
||||||
$content = array();
|
$content = array();
|
||||||
$content['msg'] = 'Hi Ralf ;-)';
|
//$content['msg'] = 'Hi Ralf ;-)';
|
||||||
$sel_options['tree'] = $this->tree_data();
|
$sel_options['tree'] = $this->tree_data();
|
||||||
$tpl->exec('admin.admin_ui.index', $content, $sel_options);
|
$tpl->exec('admin.admin_ui.index', $content, $sel_options);
|
||||||
}
|
}
|
||||||
@ -106,6 +106,7 @@ class admin_ui
|
|||||||
$data['im0'] = $icon;
|
$data['im0'] = $icon;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
unset($data['icon']);
|
||||||
$parent =& $tree['item'];
|
$parent =& $tree['item'];
|
||||||
$parts = explode('/', $data['id']);
|
$parts = explode('/', $data['id']);
|
||||||
if ($data['id'][0] == '/') array_shift($parts); // remove root
|
if ($data['id'][0] == '/') array_shift($parts); // remove root
|
||||||
@ -128,12 +129,14 @@ class admin_ui
|
|||||||
'item' => array(),
|
'item' => array(),
|
||||||
'child' => 1,
|
'child' => 1,
|
||||||
);
|
);
|
||||||
|
if ($path == '/admin') $parent[$path]['open'] = true;
|
||||||
}
|
}
|
||||||
$parent =& $parent[$path]['item'];
|
$parent =& $parent[$path]['item'];
|
||||||
}
|
}
|
||||||
$data['text'] = lang($data['text']);
|
$data['text'] = lang($data['text']);
|
||||||
if (!empty($data['title'])) $data['title'] = lang($data['title']);
|
if (!empty($data['tooltip'])) $data['tooltip'] = lang($data['tooltip']);
|
||||||
$parent[$data['id']] = $data;
|
|
||||||
|
$parent[$data['id']] = self::fix_userdata($data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -153,6 +156,28 @@ class admin_ui
|
|||||||
return $tree;
|
return $tree;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fix userdata as understood by tree
|
||||||
|
*
|
||||||
|
* @param array $data
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
private static function fix_userdata(array $data)
|
||||||
|
{
|
||||||
|
// store link as userdata, maybe we should store everything not directly understood by tree this way ...
|
||||||
|
foreach(array_diff_key($data, array_flip(array(
|
||||||
|
'id','text','tooltip','im0','im1','im2','item','child','select','open','call',
|
||||||
|
))) as $name => $content)
|
||||||
|
{
|
||||||
|
$data['userdata'][] = array(
|
||||||
|
'name' => $name,
|
||||||
|
'content' => $content,
|
||||||
|
);
|
||||||
|
unset($data[$name]);
|
||||||
|
}
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
private static function strip_item_keys(&$items)
|
private static function strip_item_keys(&$items)
|
||||||
{
|
{
|
||||||
$items = array_values($items);
|
$items = array_values($items);
|
||||||
@ -177,7 +202,7 @@ class admin_ui
|
|||||||
function display_section($appname,$file,$file2=False)
|
function display_section($appname,$file,$file2=False)
|
||||||
{
|
{
|
||||||
admin_ui::$hook_data[$appname] = $file2 ? $file2 : $file;
|
admin_ui::$hook_data[$appname] = $file2 ? $file2 : $file;
|
||||||
error_log(__METHOD__."(".array2string(func_get_args()).")");
|
//error_log(__METHOD__."(".array2string(func_get_args()).")");
|
||||||
}
|
}
|
||||||
return array_merge($GLOBALS['egw']->hooks->process('admin', array('admin')), self::$hook_data);
|
return array_merge($GLOBALS['egw']->hooks->process('admin', array('admin')), self::$hook_data);
|
||||||
}
|
}
|
||||||
|
@ -259,7 +259,7 @@ class uiconfig
|
|||||||
$t->set_var('lang_cancel', lang('Cancel'));
|
$t->set_var('lang_cancel', lang('Cancel'));
|
||||||
|
|
||||||
// set currentapp to our calling app, to show the right sidebox-menu
|
// set currentapp to our calling app, to show the right sidebox-menu
|
||||||
$GLOBALS['egw_info']['flags']['currentapp'] = $show_app;
|
// $GLOBALS['egw_info']['flags']['currentapp'] = $show_app;
|
||||||
|
|
||||||
// render the page
|
// render the page
|
||||||
$GLOBALS['egw']->framework->render(
|
$GLOBALS['egw']->framework->render(
|
||||||
|
@ -14,6 +14,7 @@ $GLOBALS['egw_info'] = array(
|
|||||||
'flags' => array(
|
'flags' => array(
|
||||||
'currentapp' => 'admin',
|
'currentapp' => 'admin',
|
||||||
'noheader' => true,
|
'noheader' => true,
|
||||||
|
'nonavbar' => true,
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
include('../header.inc.php');
|
include('../header.inc.php');
|
||||||
|
88
admin/js/app.js
Normal file
88
admin/js/app.js
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
/**
|
||||||
|
* EGroupware - Admin - Javascript UI
|
||||||
|
*
|
||||||
|
* @link http://www.egroupware.org
|
||||||
|
* @package filemanager
|
||||||
|
* @author Ralf Becker <RalfBecker-AT-outdoor-training.de>
|
||||||
|
* @copyright (c) 2013 by Ralf Becker <RalfBecker-AT-outdoor-training.de>
|
||||||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||||||
|
* @version $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UI for Admin
|
||||||
|
*
|
||||||
|
* @augments AppJS
|
||||||
|
*/
|
||||||
|
app.admin = AppJS.extend(
|
||||||
|
{
|
||||||
|
appname: 'admin',
|
||||||
|
/**
|
||||||
|
* et2 widget container
|
||||||
|
*/
|
||||||
|
et2: null,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*
|
||||||
|
* @memberOf app.filemanager
|
||||||
|
*/
|
||||||
|
init: function()
|
||||||
|
{
|
||||||
|
// call parent
|
||||||
|
this._super.apply(this, arguments);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Destructor
|
||||||
|
*/
|
||||||
|
destroy: function()
|
||||||
|
{
|
||||||
|
delete this.et2;
|
||||||
|
// call parent
|
||||||
|
this._super.apply(this, arguments);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This function is called when the etemplate2 object is loaded
|
||||||
|
* and ready. If you must store a reference to the et2 object,
|
||||||
|
* make sure to clean it up in destroy().
|
||||||
|
*
|
||||||
|
* @param _et2 etemplate2 Newly ready object
|
||||||
|
*/
|
||||||
|
et2_ready: function(_et2)
|
||||||
|
{
|
||||||
|
// call parent
|
||||||
|
this._super.apply(this, arguments);
|
||||||
|
|
||||||
|
this.et2 = _et2.widgetContainer;
|
||||||
|
|
||||||
|
var iframe = this.et2.getWidgetById('admin_iframe');
|
||||||
|
if (iframe) iframe.set_src(egw.webserverUrl+'/admin/index.php');
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run an admin module / onclick callback for tree
|
||||||
|
*
|
||||||
|
* @param string _id id of clicked node
|
||||||
|
* @param et2_tree _widget reference to tree widget
|
||||||
|
*/
|
||||||
|
run: function(_id, _widget)
|
||||||
|
{
|
||||||
|
var link = _widget.getUserData(_id, 'link');
|
||||||
|
var iframe = this.et2.getWidgetById('admin_iframe');
|
||||||
|
|
||||||
|
if (typeof link == 'undefined')
|
||||||
|
{
|
||||||
|
_widget.openItem(_id, 'toggle');
|
||||||
|
}
|
||||||
|
else if (link[0] == '/' || link.substr(0,4) == 'http')
|
||||||
|
{
|
||||||
|
iframe.set_src(link+'&nonavbar=1');
|
||||||
|
}
|
||||||
|
else if (link.substr(0,11) == 'javascript:')
|
||||||
|
{
|
||||||
|
eval(link.substr(11));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
21
admin/templates/default/app.css
Normal file
21
admin/templates/default/app.css
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
/**
|
||||||
|
* EGroupware - CSS Styles used by admin app
|
||||||
|
*
|
||||||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||||||
|
* @package etemplate
|
||||||
|
* @link http://www.egroupware.org
|
||||||
|
* @author Ralf Becker <RalfBecker@outdoor-training.de>
|
||||||
|
* @version $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
.admin_tree table, .admin_tree tr, .admin_tree td {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
div#divAppbox {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
background-image: none;
|
||||||
|
}
|
@ -2,8 +2,8 @@
|
|||||||
<!-- $Id$ -->
|
<!-- $Id$ -->
|
||||||
<overlay>
|
<overlay>
|
||||||
<template id="admin.index" template="" lang="" group="0" version="1.9.001">
|
<template id="admin.index" template="" lang="" group="0" version="1.9.001">
|
||||||
<tree autoloading="admin_ui::ajax_tree" id="tree"/><!-- onclick="app.admin.run(widget.event_args[0],widget);" parent_node="tree_target"/ -->
|
<tree autoloading="admin_ui::ajax_tree" id="admin_tree" onclick="app.admin.run(widget.event_args[0],widget);" parent_node="admin_tree_target"/>
|
||||||
<html id="msg"/>
|
<html id="msg"/>
|
||||||
<!-- iframe frameborder="1" height="auto" id="iframe" scrolling="auto" width="100%"/ -->
|
<iframe frameborder="1" height="500px" id="admin_iframe" scrolling="auto" width="100%"/>
|
||||||
</template>
|
</template>
|
||||||
</overlay>
|
</overlay>
|
||||||
|
@ -570,6 +570,66 @@ var et2_tree = et2_inputWidget.extend(
|
|||||||
}
|
}
|
||||||
//alert(returnValue.join('#,#'));
|
//alert(returnValue.join('#,#'));
|
||||||
return returnValue;
|
return returnValue;
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch user-data stored in specified node under given name
|
||||||
|
*
|
||||||
|
* User-data need to be stored in json as follows:
|
||||||
|
*
|
||||||
|
* {"id": "node-id", "im0": ..., "userdata": [{"name": "user-name", "content": "user-value"},...]}
|
||||||
|
*
|
||||||
|
* In above example getUserData("node-id", "user-name") will return "user-value"
|
||||||
|
*
|
||||||
|
* @param _nodeId
|
||||||
|
* @param _name
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
getUserData: function(_nodeId, _name)
|
||||||
|
{
|
||||||
|
if(this.input == null) return null;
|
||||||
|
return this.input.getUserData(_nodeId, _name);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Stores / updates user-data in specified node and name
|
||||||
|
*
|
||||||
|
* @param _nodeId
|
||||||
|
* @param _name
|
||||||
|
* @param _value
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
setUserData: function(_nodeId, _name, _value)
|
||||||
|
{
|
||||||
|
if(this.input == null) return null;
|
||||||
|
return this.input.setUserData(_nodeId, _name, _value);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Query nodes open state and optinal change it
|
||||||
|
*
|
||||||
|
* @param _id node-id
|
||||||
|
* @param _open specify to change true: open, false: close, everything else toggle
|
||||||
|
* @returns true if open, false if closed
|
||||||
|
*/
|
||||||
|
openItem: function(_id, _open)
|
||||||
|
{
|
||||||
|
if (this.input == null) return null;
|
||||||
|
|
||||||
|
var is_open = this.input.getOpenState(_id) == 1;
|
||||||
|
|
||||||
|
if (typeof _open != 'undefined' && is_open !== _open)
|
||||||
|
{
|
||||||
|
if(is_open)
|
||||||
|
{
|
||||||
|
this.input.closeItem(_id);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.input.openItem(_id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return is_open;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
et2_register_widget(et2_tree, ["tree","tree-cat"]);
|
et2_register_widget(et2_tree, ["tree","tree-cat"]);
|
||||||
|
@ -127,6 +127,12 @@ class idots_framework extends egw_framework
|
|||||||
function navbar()
|
function navbar()
|
||||||
{
|
{
|
||||||
if (self::$navbar_done) return '';
|
if (self::$navbar_done) return '';
|
||||||
|
|
||||||
|
if (!empty($_GET['nonavbar']) || $GLOBALS['egw_info']['flags']['currentapp'] == 'admin' && empty($_GET['ajax']))
|
||||||
|
{
|
||||||
|
if (!self::$header_done) return $this->header();
|
||||||
|
return '';
|
||||||
|
}
|
||||||
self::$navbar_done = true;
|
self::$navbar_done = true;
|
||||||
|
|
||||||
// the navbar
|
// the navbar
|
||||||
@ -722,7 +728,8 @@ egw.set_user('.$GLOBALS['egw']->accounts->json($GLOBALS['egw_info']['user']['acc
|
|||||||
$this->tpl->set_var($this->_get_footer());
|
$this->tpl->set_var($this->_get_footer());
|
||||||
$content .= $this->tpl->fp('out','footer');
|
$content .= $this->tpl->fp('out','footer');
|
||||||
}
|
}
|
||||||
elseif (!isset($GLOBALS['egw_info']['flags']['noheader']) || !$GLOBALS['egw_info']['flags']['noheader'])
|
elseif (!isset($GLOBALS['egw_info']['flags']['noheader']) || !$GLOBALS['egw_info']['flags']['noheader'] ||
|
||||||
|
!empty($_GET['nonavbar']) || $GLOBALS['egw_info']['flags']['currentapp'] == 'admin' && empty($_GET['ajax']))
|
||||||
{
|
{
|
||||||
$content .= "</body>\n</html>\n"; // close body and html tag, eg. for popups
|
$content .= "</body>\n</html>\n"; // close body and html tag, eg. for popups
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user