Home improvements - Weekend toggle, weekN & month support

This commit is contained in:
Nathan Gray 2016-02-22 22:45:48 +00:00
parent 4c4a9a0e8d
commit 9460e1a2f9
6 changed files with 77 additions and 86 deletions

View File

@ -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);

View File

@ -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)
{ {

View File

@ -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 ';

View File

@ -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,42 +553,36 @@ 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);
for($i = 0; $i < $weeks; $i++)
{
$timespan[] = array(
'start' => strtotime("+$i weeks", $this->first),
'end' => strtotime('+' . ($i+1).' weeks', $this->first) -1
);
}
} else {
$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(
'menuaction' => 'calendar.calendar_uiviews.index',
'msg' => $merge,
));
}
$list = $this->cal_prefs['use_time_grid'];
if(!is_array($list))
{
$list = explode(',',$list);
}
if(is_array($list))
{
$granularity = in_array('weekN',$list) ? 0 : $granularity;
}
}
$content = array('view' => array());
if ($weeks) if ($weeks)
{ {
$this->first = $this->datetime->get_weekday_start($this->year,$this->month,$this->day); $this->first = $this->datetime->get_weekday_start($this->year,$this->month,$this->day);
@ -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;
$days =& $this->bo->search(array( $week_start = new egw_time($this->first);
'start' => $this->first, $week_start->setTime(0,0,0);
'end' => $this->last, $week_end = new egw_time($week_start);
)+$this->search_params); $week_end->add(new DateInterval('P6DT23H59M59S'));
$last = new egw_time($this->last);
// we add DAY_s/2 to $this->first (using 12h), to deal with daylight saving changes for ($week_start; $week_start < $last; $week_start->add('1 week'), $week_end->add('1 week'))
for ($week_start = $this->first; $week_start < $this->last; $week_start = strtotime("+1 week",$week_start))
{ {
$week = array(); $search_params = $this->search_params;
for ($i = 0; $i < 7; ++$i) $search_params['start'] = $week_start->format('ts');
{ $search_params['end'] = $week_end->format('ts');
$day_ymd = $this->bo->date2string($i ? strtotime("+$i days",$week_start) : $week_start);
$week[$day_ymd] = array_shift($days); $content['view'][] = (array)$this->tagWholeDayOnTop($this->bo->search($search_params));
} $home->setElementAttribute("view[$week]",'onchange',false);
$week_view = array( $home->setElementAttribute("view[$week]",'granularity',$granularity);
'menuaction' => 'calendar.calendar_uiviews.week', $home->setElementAttribute("view[$week]",'show_weekend', $this->search_params['weekend']);
'date' => $this->bo->date2string($week_start), $week++;
);
$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);
} }
$navHeader = '<div class="calendar_calMonthNavHeader calendar_calMonth">' $home->exec(__METHOD__, $content);
.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());

View File

@ -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();
} }
} }
}, },

View File

@ -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) {