mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-05 05:29:13 +01:00
Home improvements - Weekend toggle, weekN & month support
This commit is contained in:
parent
4c4a9a0e8d
commit
9460e1a2f9
@ -81,6 +81,7 @@ class calendar_favorite_portlet extends home_favorite_portlet
|
|||||||
}
|
}
|
||||||
if($this->favorite['state']['filter']) $ui->search_params['filter'] = $this->favorite['state']['filter'];
|
if($this->favorite['state']['filter']) $ui->search_params['filter'] = $this->favorite['state']['filter'];
|
||||||
if($this->favorite['state']['sortby']) $ui->search_params['sortby'] = $this->favorite['state']['sortby'];
|
if($this->favorite['state']['sortby']) $ui->search_params['sortby'] = $this->favorite['state']['sortby'];
|
||||||
|
$ui->search_params['weekend'] = $this->favorite['state']['weekend'];
|
||||||
}
|
}
|
||||||
$etemplate->read('home.legacy');
|
$etemplate->read('home.legacy');
|
||||||
|
|
||||||
@ -114,15 +115,18 @@ class calendar_favorite_portlet extends home_favorite_portlet
|
|||||||
$ui->planner_view = $this->favorite['state']['planner_view'];
|
$ui->planner_view = $this->favorite['state']['planner_view'];
|
||||||
$ui->planner(array(), $etemplate);
|
$ui->planner(array(), $etemplate);
|
||||||
return;
|
return;
|
||||||
case 'year':
|
|
||||||
$content = array('legacy' => $ui->year(true));
|
|
||||||
break;
|
|
||||||
case 'month':
|
case 'month':
|
||||||
$content = array('legacy' => $ui->month(0,true));
|
|
||||||
break;
|
|
||||||
case 'weekN':
|
case 'weekN':
|
||||||
$content = array('legacy' => $ui->weekN(true));
|
$etemplate->read('calendar.view');
|
||||||
break;
|
$etemplate->set_dom_id($id);
|
||||||
|
$this->actions =& $etemplate->getElementAttribute('view', 'actions');
|
||||||
|
|
||||||
|
$ui->month($this->favorite['state']['view'] == 'month' ?
|
||||||
|
0 :
|
||||||
|
(int)$ui->cal_prefs['multiple_weeks'],
|
||||||
|
$etemplate
|
||||||
|
);
|
||||||
|
return;
|
||||||
case 'week':
|
case 'week':
|
||||||
$etemplate->read('calendar.view');
|
$etemplate->read('calendar.view');
|
||||||
$etemplate->set_dom_id($id);
|
$etemplate->set_dom_id($id);
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
{
|
{
|
||||||
$form_name = self::form_name($cname, $this->id, $expand);
|
$form_name = self::form_name($cname, $this->id, $expand);
|
||||||
$value =& self::get_array(self::$request->content, $form_name, true);
|
$value =& self::get_array(self::$request->content, $form_name, true);
|
||||||
|
if(!is_array($value)) $value = array();
|
||||||
|
|
||||||
foreach($value as $day => &$events)
|
foreach($value as $day => &$events)
|
||||||
{
|
{
|
||||||
|
@ -714,6 +714,8 @@ class calendar_ui
|
|||||||
*/
|
*/
|
||||||
public function to_client(&$event)
|
public function to_client(&$event)
|
||||||
{
|
{
|
||||||
|
if(!$event || !is_array($event)) return false;
|
||||||
|
|
||||||
if (!$this->bo->check_perms(EGW_ACL_EDIT,$event))
|
if (!$this->bo->check_perms(EGW_ACL_EDIT,$event))
|
||||||
{
|
{
|
||||||
$event['class'] .= 'rowNoEdit ';
|
$event['class'] .= 'rowNoEdit ';
|
||||||
|
@ -540,7 +540,7 @@ class calendar_uiviews extends calendar_ui
|
|||||||
/**
|
/**
|
||||||
* Displays a multiple week-view
|
* Displays a multiple week-view
|
||||||
*
|
*
|
||||||
* @param boolean $home = false if true return content suitable for home-page
|
* @param boolean|etemplate2 $home = false if not false return content suitable for home-page
|
||||||
*/
|
*/
|
||||||
function &weekN($home=false)
|
function &weekN($home=false)
|
||||||
{
|
{
|
||||||
@ -553,41 +553,35 @@ class calendar_uiviews extends calendar_ui
|
|||||||
* Displays the monthview or a multiple week-view
|
* Displays the monthview or a multiple week-view
|
||||||
*
|
*
|
||||||
* @param int $weeks = 0 number of weeks to show, if 0 (default) all weeks of one month are shown
|
* @param int $weeks = 0 number of weeks to show, if 0 (default) all weeks of one month are shown
|
||||||
* @param boolean $home = false if true return content suitable for home-page
|
* @param boolean|etemplate2 $home = false if not false return content suitable for home-page
|
||||||
*/
|
*/
|
||||||
function &month($weeks=0,$home=false)
|
function &month($weeks=0,$home=false)
|
||||||
{
|
{
|
||||||
if ($this->debug > 0) $this->bo->debug_message('uiviews::month(weeks=%1) date=%2',True,$weeks,$this->date);
|
if ($this->debug > 0) $this->bo->debug_message('uiviews::month(weeks=%1) date=%2',True,$weeks,$this->date);
|
||||||
|
|
||||||
$this->use_time_grid = !$this->use_time_grid_pref || $this->use_time_grid_pref == 'all'; // all views
|
if (!$home)
|
||||||
|
{
|
||||||
|
trigger_error(__METHOD__ .' only used by home app', E_USER_DEPRECATED);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Merge print
|
$this->use_time_grid = !$this->use_time_grid_pref || $this->use_time_grid_pref == 'all'; // all views
|
||||||
|
$granularity = 0;
|
||||||
if($weeks)
|
if($weeks)
|
||||||
{
|
{
|
||||||
// Split up span into multiple weeks
|
$granularity = ($this->cal_prefs['interval'] ? (int)$this->cal_prefs['interval'] : 30);
|
||||||
$timespan = array();
|
|
||||||
$this->first = $this->datetime->get_weekday_start($this->year,$this->month,$this->day);
|
$list = $this->cal_prefs['use_time_grid'];
|
||||||
for($i = 0; $i < $weeks; $i++)
|
if(!is_array($list))
|
||||||
{
|
{
|
||||||
$timespan[] = array(
|
$list = explode(',',$list);
|
||||||
'start' => strtotime("+$i weeks", $this->first),
|
|
||||||
'end' => strtotime('+' . ($i+1).' weeks', $this->first) -1
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
} else {
|
if(is_array($list))
|
||||||
$timespan[] = array(
|
|
||||||
'start' => mktime(0,0,0,$this->month,1,$this->year),
|
|
||||||
'end' => mktime(0,0,0,$this->month+1,1,$this->year)-1
|
|
||||||
);
|
|
||||||
}
|
|
||||||
$merge = $this->merge($timespan);
|
|
||||||
if($merge)
|
|
||||||
{
|
{
|
||||||
egw::redirect_link('/index.php',array(
|
$granularity = in_array('weekN',$list) ? 0 : $granularity;
|
||||||
'menuaction' => 'calendar.calendar_uiviews.index',
|
|
||||||
'msg' => $merge,
|
|
||||||
));
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
$content = array('view' => array());
|
||||||
|
|
||||||
if ($weeks)
|
if ($weeks)
|
||||||
{
|
{
|
||||||
@ -605,55 +599,27 @@ class calendar_uiviews extends calendar_ui
|
|||||||
}
|
}
|
||||||
if ($this->debug > 0) $this->bo->debug_message('uiviews::month(%1) date=%2: first=%3, last=%4',False,$weeks,$this->date,$this->bo->date2string($this->first),$this->bo->date2string($this->last));
|
if ($this->debug > 0) $this->bo->debug_message('uiviews::month(%1) date=%2: first=%3, last=%4',False,$weeks,$this->date,$this->bo->date2string($this->first),$this->bo->date2string($this->last));
|
||||||
|
|
||||||
$GLOBALS['egw_info']['flags']['app_header'] .= ': '.$navHeader;
|
// Loop through, using egw_time to handle DST
|
||||||
|
$week = 0;
|
||||||
|
$week_start = new egw_time($this->first);
|
||||||
|
$week_start->setTime(0,0,0);
|
||||||
|
$week_end = new egw_time($week_start);
|
||||||
|
$week_end->add(new DateInterval('P6DT23H59M59S'));
|
||||||
|
$last = new egw_time($this->last);
|
||||||
|
for ($week_start; $week_start < $last; $week_start->add('1 week'), $week_end->add('1 week'))
|
||||||
|
{
|
||||||
|
$search_params = $this->search_params;
|
||||||
|
$search_params['start'] = $week_start->format('ts');
|
||||||
|
$search_params['end'] = $week_end->format('ts');
|
||||||
|
|
||||||
$days =& $this->bo->search(array(
|
$content['view'][] = (array)$this->tagWholeDayOnTop($this->bo->search($search_params));
|
||||||
'start' => $this->first,
|
$home->setElementAttribute("view[$week]",'onchange',false);
|
||||||
'end' => $this->last,
|
$home->setElementAttribute("view[$week]",'granularity',$granularity);
|
||||||
)+$this->search_params);
|
$home->setElementAttribute("view[$week]",'show_weekend', $this->search_params['weekend']);
|
||||||
|
$week++;
|
||||||
// we add DAY_s/2 to $this->first (using 12h), to deal with daylight saving changes
|
|
||||||
for ($week_start = $this->first; $week_start < $this->last; $week_start = strtotime("+1 week",$week_start))
|
|
||||||
{
|
|
||||||
$week = array();
|
|
||||||
for ($i = 0; $i < 7; ++$i)
|
|
||||||
{
|
|
||||||
$day_ymd = $this->bo->date2string($i ? strtotime("+$i days",$week_start) : $week_start);
|
|
||||||
$week[$day_ymd] = array_shift($days);
|
|
||||||
}
|
|
||||||
$week_view = array(
|
|
||||||
'menuaction' => 'calendar.calendar_uiviews.week',
|
|
||||||
'date' => $this->bo->date2string($week_start),
|
|
||||||
);
|
|
||||||
$title = lang('Wk').' '.$this->week_number($week_start);
|
|
||||||
if ($this->allowEdit)
|
|
||||||
{
|
|
||||||
$title = html::a_href($title,$week_view,'',' title="'.lang('Weekview').'"');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$content .= $this->timeGridWidget($this->tagWholeDayOnTop($week),$weeks == 2 ? 30 : 60,200,'',$title,0,$week_start+WEEK_s >= $this->last);
|
$home->exec(__METHOD__, $content);
|
||||||
}
|
|
||||||
|
|
||||||
$navHeader = '<div class="calendar_calMonthNavHeader calendar_calMonth">'
|
|
||||||
.html::a_href(html::image('phpgwapi','left',lang('previous'),$options=' alt="<<"'),array(
|
|
||||||
'menuaction' => $this->view_menuaction,
|
|
||||||
'date' => date('Ymd',strtotime("-".$weekNavH, $weeks? $this->first: $this->bo->date2ts($this->date))),
|
|
||||||
)). ' <span>'.$navHeader;
|
|
||||||
|
|
||||||
$navHeader = $navHeader.'</span> '.html::a_href(html::image('phpgwapi','right',lang('next'),$options=' alt=">>"'),array(
|
|
||||||
'menuaction' => $this->view_menuaction,
|
|
||||||
'date' => date('Ymd',strtotime("+".$weekNavH, $weeks? $this->first: $this->bo->date2ts($this->date))),
|
|
||||||
)).'</div>';
|
|
||||||
$content = $navHeader.$content;
|
|
||||||
if (!$home)
|
|
||||||
{
|
|
||||||
$this->do_header();
|
|
||||||
|
|
||||||
echo $content;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
return $content;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -736,7 +702,7 @@ class calendar_uiviews extends calendar_ui
|
|||||||
* Displays the weekview, with 5 or 7 days
|
* Displays the weekview, with 5 or 7 days
|
||||||
*
|
*
|
||||||
* @param int $days = 0 number of days to show, if 0 (default) the value from the URL or the prefs is used
|
* @param int $days = 0 number of days to show, if 0 (default) the value from the URL or the prefs is used
|
||||||
* @param boolean $home = false if true return content suitable for home-page
|
* @param boolean|etemplate2 $home = false if not false return content suitable for home-page
|
||||||
*/
|
*/
|
||||||
function week($days=0,$home=false)
|
function week($days=0,$home=false)
|
||||||
{
|
{
|
||||||
@ -757,6 +723,7 @@ class calendar_uiviews extends calendar_ui
|
|||||||
{
|
{
|
||||||
$wd_start = $this->first = $this->bo->date2ts($this->date);
|
$wd_start = $this->first = $this->bo->date2ts($this->date);
|
||||||
$this->last = strtotime("+$days days",$this->first) - 1;
|
$this->last = strtotime("+$days days",$this->first) - 1;
|
||||||
|
$view = $days == 1 ? 'day' : 'day4';
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -774,6 +741,19 @@ class calendar_uiviews extends calendar_ui
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$this->last = strtotime("+$days days",$this->first) - 1;
|
$this->last = strtotime("+$days days",$this->first) - 1;
|
||||||
|
$view = 'week';
|
||||||
|
}
|
||||||
|
|
||||||
|
$granularity = ($this->cal_prefs['interval'] ? (int)$this->cal_prefs['interval'] : 30);
|
||||||
|
|
||||||
|
$list = $this->cal_prefs['use_time_grid'];
|
||||||
|
if(!is_array($list))
|
||||||
|
{
|
||||||
|
$list = explode(',',$list);
|
||||||
|
}
|
||||||
|
if(is_array($list))
|
||||||
|
{
|
||||||
|
$granularity = in_array($view,$list) ? 0 : $granularity;
|
||||||
}
|
}
|
||||||
|
|
||||||
$search_params = array(
|
$search_params = array(
|
||||||
@ -821,7 +801,11 @@ class calendar_uiviews extends calendar_ui
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
$tmpl = $home ? $home :new etemplate_new('calendar.view');
|
$tmpl = $home ? $home :new etemplate_new('calendar.view');
|
||||||
$tmpl->setElementAttribute('view','show_weekend', $days == 7);
|
foreach($content['view'] as $index => $week)
|
||||||
|
{
|
||||||
|
$tmpl->setElementAttribute("view[$index]",'granularity',$granularity);
|
||||||
|
$tmpl->setElementAttribute("view[$index]",'show_weekend',$this->search_params['weekend']);
|
||||||
|
}
|
||||||
|
|
||||||
// Get the actions
|
// Get the actions
|
||||||
$tmpl->setElementAttribute('view','actions',$this->get_actions());
|
$tmpl->setElementAttribute('view','actions',$this->get_actions());
|
||||||
|
@ -1294,7 +1294,7 @@ app.classes.calendar = AppJS.extend(
|
|||||||
dates.set_disabled(filter.value !== "custom");
|
dates.set_disabled(filter.value !== "custom");
|
||||||
if (filter.value == "custom")
|
if (filter.value == "custom")
|
||||||
{
|
{
|
||||||
jQuery(this.et2.getWidgetById('startdate').getDOMNode()).find('input').focus();
|
jQuery(view.getWidgetById('startdate').getDOMNode()).find('input').focus();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -1781,7 +1781,7 @@ var et2_calendar_timegrid = et2_calendar_view.extend([et2_IDetachedDOM, et2_IRes
|
|||||||
{
|
{
|
||||||
this.options.height = Math.max(this.options.height, needed);
|
this.options.height = Math.max(this.options.height, needed);
|
||||||
// Set all others to match
|
// Set all others to match
|
||||||
if(!_too_small)
|
if(!_too_small && rowCount > 1)
|
||||||
{
|
{
|
||||||
window.setTimeout(jQuery.proxy(function() {
|
window.setTimeout(jQuery.proxy(function() {
|
||||||
this._parent.iterateOver(function(widget) {
|
this._parent.iterateOver(function(widget) {
|
||||||
|
Loading…
Reference in New Issue
Block a user