"bugfixes for sidebox menu under prefs or admin:

- do NOT process the $_REQUEST vars
- if user changes selectboxes, go to default calendar view"
This commit is contained in:
Ralf Becker 2009-04-20 15:44:24 +00:00
parent 2d438c6dc5
commit 9e3c1df37a

View File

@ -5,7 +5,7 @@
* @link http://www.egroupware.org * @link http://www.egroupware.org
* @package calendar * @package calendar
* @author Ralf Becker <RalfBecker-AT-outdoor-training.de> * @author Ralf Becker <RalfBecker-AT-outdoor-training.de>
* @copyright (c) 2004-8 by RalfBecker-At-outdoor-training.de * @copyright (c) 2004-9 by 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$
*/ */
@ -119,7 +119,7 @@ class calendar_ui
* @var int $last last day of the shown view * @var int $last last day of the shown view
*/ */
var $last; var $last;
/** /**
* @var array $states_to_save all states that will be saved to the user prefs * @var array $states_to_save all states that will be saved to the user prefs
*/ */
@ -252,16 +252,16 @@ class calendar_ui
function manage_states($set_states=NULL) function manage_states($set_states=NULL)
{ {
$states = $states_session = $GLOBALS['egw']->session->appsession('session_data','calendar'); $states = $states_session = $GLOBALS['egw']->session->appsession('session_data','calendar');
// retrieve saved states from prefs // retrieve saved states from prefs
if(!$states) if(!$states)
{ {
$states = unserialize($this->bo->cal_prefs['saved_states']); $states = unserialize($this->bo->cal_prefs['saved_states']);
} }
// only look at _REQUEST, if we are in the calendar (prefs and admin show our sidebox menu too!)
if (is_null($set_states)) if (is_null($set_states))
{ {
$set_states = $_REQUEST; $set_states = substr($_GET['menuaction'],0,9) == 'calendar.' ? $_REQUEST : array();
} }
if (!$states['date'] && $states['year'] && $states['month'] && $states['day']) if (!$states['date'] && $states['year'] && $states['month'] && $states['day'])
{ {
@ -336,7 +336,7 @@ class calendar_ui
$states['view'] = $this->view = 'planner'; $states['view'] = $this->view = 'planner';
} }
// set the actual view as return_to // set the actual view as return_to
if ($_GET['menuaction'] && $_GET['menuaction']) if (isset($_GET['menuaction']))
{ {
list($app,$class,$func) = explode('.',$_GET['menuaction']); list($app,$class,$func) = explode('.',$_GET['menuaction']);
if ($func == 'index') if ($func == 'index')
@ -455,7 +455,7 @@ class calendar_ui
{ {
if ($baseurl) // we append the value to the baseurl if ($baseurl) // we append the value to the baseurl
{ {
$baseurl .= strpos($baseurl,'?') === False ? '?' : '&'; if (substr($baseurl,-1) != '=') $baseurl .= strpos($baseurl,'?') === False ? '?' : '&';
$onchange="location='$baseurl'+this.value;"; $onchange="location='$baseurl'+this.value;";
} }
else // we add $name=value to the actual location else // we add $name=value to the actual location
@ -681,15 +681,21 @@ class calendar_ui
$link['week'],lang('show this week'),$link['month'],lang('show this month')); $link['week'],lang('show this week'),$link['month'],lang('show this month'));
$file[++$n] = array('text' => $jscalendar,'no_lang' => True,'link' => False,'icon' => False); $file[++$n] = array('text' => $jscalendar,'no_lang' => True,'link' => False,'icon' => False);
// set a baseurl for selectboxes, if we are not running inside calendar (eg. prefs or admin)
if (substr($_GET['menuaction'],0,9) != 'calendar.')
{
$baseurl = egw::link('/index.php',array('menuaction'=>'calendar.calendar_uiviews.index'));
}
// Category Selection // Category Selection
$file[++$n] = $this->_select_box('Category','cat_id', $file[++$n] = $this->_select_box('Category','cat_id',
'<option value="0">'.lang('All categories').'</option>'. '<option value="0">'.lang('All categories').'</option>'.
$this->cats->formatted_list('select','all',$this->cat_id,'True')); $this->cats->formatted_list('select','all',$this->cat_id,'True'),$baseurl ? $baseurl.'&cat_id=' : '');
// Filter all or hideprivate // Filter all or hideprivate
$file[] = $this->_select_box('Filter','filter', $file[] = $this->_select_box('Filter','filter',
'<option value="all"'.($this->filter=='all'?' selected="selected"':'').'>'.lang('No filter').'</option>'."\n". '<option value="all"'.($this->filter=='all'?' selected="selected"':'').'>'.lang('No filter').'</option>'."\n".
'<option value="hideprivate"'.($this->filter=='hideprivate'?' selected="selected"':'').'>'.lang('Hide private infos').'</option>'."\n"); '<option value="hideprivate"'.($this->filter=='hideprivate'?' selected="selected"':'').'>'.lang('Hide private infos').'</option>'."\n",
$baseurl ? $baseurl.'&filter=' : '');
// Calendarselection: User or Group // Calendarselection: User or Group
if(count($this->bo->grants) > 0 && $this->accountsel->account_selection != 'none') if(count($this->bo->grants) > 0 && $this->accountsel->account_selection != 'none')