calendar: added posted/created chronology

calendar: added a where are we bar (like: created/2005/august)

calendar: possibility to hide the All/Any buttons ($conf['calendar_show_any'])

calendar: possibility to display a single navigation bar instead of 
several navigation bars ($conf['calendar_multi_bar'])

calendar: tried to simplify code and improve readability 
(still requires a review)

git-svn-id: http://piwigo.org/svn/trunk@1057 68402e56-0260-453c-a942-63ccdbb3a9ee
This commit is contained in:
rvelices 2006-02-24 05:58:48 +00:00
parent 3aff4f0bfe
commit d4646f39d2
9 changed files with 394 additions and 261 deletions

View file

@ -301,7 +301,7 @@ $template->assign_block_vars(
$template->assign_block_vars(
'special_cat',
array(
'URL' => PHPWG_ROOT_PATH.'category.php?calendar=m-c',
'URL' => PHPWG_ROOT_PATH.'category.php?calendar=monthly-c',
'TITLE' => $lang['calendar_hint'],
'NAME' => $lang['calendar']
));

View file

@ -35,24 +35,40 @@ class CalendarBase
var $inner_sql;
// base url used when generating html links
var $url_base;
// array of date components e.g. (2005,10,12) ...
var $date_components;
function get_date_where()
{
die("get_date_where not extended");
}
/**
* Initialize the calendar
* @param string date_field db column on which this calendar works
* @param string inner_sql used for queries (INNER JOIN or normal)
* @param array date_components
*/
function initialize($date_field, $inner_sql)
function initialize($date_field, $inner_sql, $date_components)
{
$this->date_field = $date_field;
$this->inner_sql = $inner_sql;
$this->date_components = $date_components;
}
//--------------------------------------------------------- private members ---
/**
* Returns a display name for a date component optionally using labels
*/
function get_date_component_label($date_component, $labels=null)
{
$label = $date_component;
if (isset($labels[$date_component]))
{
$label = $labels[$date_component];
}
elseif ($date_component == 'any' )
{
$label = l10n('calendar_any');
}
return $label;
}
/**
* Creates a calendar navigation bar.
@ -96,8 +112,8 @@ class CalendarBase
}
$nav_bar.= '</span>';
}
if ($allow_any and count($items) > 1)
global $conf;
if ($conf['calendar_show_any'] and $allow_any and count($items) > 1)
{
$label = l10n('calendar_any');
if (isset($selected_item) and 'any' == $selected_item)
@ -121,14 +137,12 @@ class CalendarBase
/**
* Creates a calendar navigation bar for a given level.
*
* @param string view_type - list or calendar (e.g. 'l' or 'c')
* @param array requested - array of current selected elements (e.g. 2005,10)
* @param string sql_func - YEAR/MONTH/DAY/WEEK/DAYOFWEEK ...
* @param string sql_offset - (e.g. +1 for WEEK - first in year is 1)
* @param array labels - optional labels to show in the navigation bar
* @return void
*/
function build_nav_bar($view_type, $requested, $level, $sql_func,
function build_nav_bar($level, $sql_func,
$sql_offset='', $labels=null)
{
global $template;
@ -137,7 +151,7 @@ class CalendarBase
SELECT DISTINCT('.$sql_func.'('.$this->date_field.')'.$sql_offset
.') as period';
$query.= $this->inner_sql;
$query.= $this->get_date_where($requested, $level);
$query.= $this->get_date_where($level);
$query.= '
GROUP BY period
;';
@ -150,19 +164,22 @@ SELECT DISTINCT('.$sql_func.'('.$this->date_field.')'.$sql_offset
}
$url_base = $this->url_base;
$url_base .= $view_type.'-';
for ($i=0; $i<$level; $i++)
{
if (isset($requested[$i]))
if (isset($this->date_components[$i]))
{
$url_base .= $requested[$i].'-';
$url_base .= $this->date_components[$i].'-';
}
}
$selected = null;
if ( isset($this->date_components[$level]) )
{
$selected = $this->date_components[$level];
}
$nav_bar = $this->get_nav_bar_from_items(
$url_base,
$level_items,
isset($requested[$level]) ? $requested[$level] : null,
$selected,
'cal',
true,
$labels

View file

@ -26,6 +26,10 @@
include_once(PHPWG_ROOT_PATH.'include/calendar_base.class.php');
define ('CYEAR', 0);
define ('CMONTH', 1);
define ('CDAY', 2);
/**
* Monthly calendar style (composed of years/months and days)
*/
@ -37,43 +41,62 @@ class Calendar extends CalendarBase
* @return boolean false to indicate that thumbnails
* where not included here, true otherwise
*/
function generate_category_content($url_base, $view_type, &$requested)
function generate_category_content($url_base, $view_type)
{
global $lang;
global $lang, $conf;
$this->url_base = $url_base;
if ($view_type==CAL_VIEW_CALENDAR and count($requested)==0)
if ($view_type==CAL_VIEW_CALENDAR)
{
if ( count($this->date_components)==0 )
{//case A: no year given - display all years+months
if ($this->build_global_calendar($requested))
if ($this->build_global_calendar())
return true;
}
if ($view_type==CAL_VIEW_CALENDAR and count($requested)==1)
if ( count($this->date_components)==1 )
{//case B: year given - display all days in given year
if ($this->build_year_calendar($requested))
if ($this->build_year_calendar())
{
$this->build_nav_bar2($view_type, $requested, 0, 'YEAR'); // years
if ( $conf['calendar_multi_bar'] )
$this->build_nav_bar2(CYEAR, 'YEAR'); // years
return true;
}
}
if ($view_type==CAL_VIEW_CALENDAR and count($requested)==2)
if ( count($this->date_components)==2 )
{//case C: year+month given - display a nice month calendar
$this->build_month_calendar($requested);
$this->build_nav_bar2(CAL_VIEW_CALENDAR, $requested, 0, 'YEAR'); // years
if (count($requested)>0)
$this->build_nav_bar2(CAL_VIEW_CALENDAR, $requested, 1, 'MONTH', $lang['month']); // month
$this->build_month_calendar();
if ( $conf['calendar_multi_bar'] )
{
$this->build_nav_bar2(CYEAR, 'YEAR'); // years
}
if (count($this->date_components)>=1 and
( $conf['calendar_multi_bar'] or count($this->date_components)==1 ) )
{
$this->build_nav_bar2(CMONTH, 'MONTH', $lang['month']); // month
}
return true;
}
}
if ($view_type==CAL_VIEW_LIST or count($requested)==3)
if ($view_type==CAL_VIEW_LIST or count($this->date_components)==3)
{
$this->build_nav_bar2($view_type, $requested, 0, 'YEAR'); // years
if (count($requested)>0)
$this->build_nav_bar2($view_type, $requested, 1, 'MONTH', $lang['month']); // month
if (count($requested)>1)
$this->build_nav_bar2($view_type, $requested, 2, 'DAYOFMONTH' ); // days
if ( $conf['calendar_multi_bar'] or count($this->date_components)==0 )
{
$this->build_nav_bar2(CYEAR, 'YEAR'); // years
}
if ( count($this->date_components)>=1 and
( $conf['calendar_multi_bar'] or count($this->date_components)==1 )
)
{
$this->build_nav_bar2(CMONTH, 'MONTH', $lang['month']); // month
}
if ( count($this->date_components)>=2 )
{
$this->build_nav_bar2(CDAY, 'DAYOFMONTH' ); // days
}
}
return false;
}
@ -81,31 +104,30 @@ function generate_category_content($url_base, $view_type, &$requested)
/**
* Returns a sql where subquery for the date field
* @param array requested selected levels for this calendar
* (e.g. 2005,11,5 for 5th of November 2005)
* @param int max_levels return the where up to this level
* (e.g. 2=only year and month)
* @return string
*/
function get_date_where($requested, $max_levels=3)
function get_date_where($max_levels=3)
{
while (count($requested)>$max_levels)
$date = $this->date_components;
while (count($date)>$max_levels)
{
array_pop($requested);
array_pop($date);
}
$res = '';
if (isset($requested[0]) and $requested[0]!='any')
if (isset($date[CYEAR]) and $date[CYEAR]!='any')
{
$b = $requested[0] . '-';
$e = $requested[0] . '-';
if (isset($requested[1]) and $requested[1]!='any')
$b = $date[CYEAR] . '-';
$e = $date[CYEAR] . '-';
if (isset($date[CMONTH]) and $date[CMONTH]!='any')
{
$b .= $requested[1] . '-';
$e .= $requested[1] . '-';
if (isset($requested[2]) and $requested[2]!='any')
$b .= $date[CMONTH] . '-';
$e .= $date[CMONTH] . '-';
if (isset($date[CDAY]) and $date[CDAY]!='any')
{
$b .= $requested[2];
$e .= $requested[2];
$b .= $date[CDAY];
$e .= $date[CDAY];
}
else
{
@ -117,13 +139,13 @@ function get_date_where($requested, $max_levels=3)
{
$b .= '01-01';
$e .= '12-31';
if (isset($requested[1]) and $requested[1]!='any')
if (isset($date[CMONTH]) and $date[CMONTH]!='any')
{
$res .= ' AND MONTH('.$this->date_field.')='.$requested[1];
$res .= ' AND MONTH('.$this->date_field.')='.$date[CMONTH];
}
if (isset($requested[2]) and $requested[2]!='any')
if (isset($date[2]) and $date[2]!='any')
{
$res .= ' AND DAYOFMONTH('.$this->date_field.')='.$requested[2];
$res .= ' AND DAYOFMONTH('.$this->date_field.')='.$date[CDAY];
}
}
$res = " AND $this->date_field BETWEEN '$b' AND '$e 23:59:59'" . $res;
@ -131,31 +153,72 @@ function get_date_where($requested, $max_levels=3)
else
{
$res = ' AND '.$this->date_field.' IS NOT NULL';
if (isset($requested[1]) and $requested[1]!='any')
if (isset($date[CMONTH]) and $date[CMONTH]!='any')
{
$res .= ' AND MONTH('.$this->date_field.')='.$requested[1];
$res .= ' AND MONTH('.$this->date_field.')='.$date[CMONTH];
}
if (isset($requested[2]) and $requested[2]!='any')
if (isset($date[CDAY]) and $date[CDAY]!='any')
{
$res .= ' AND DAYOFMONTH('.$this->date_field.')='.$requested[2];
$res .= ' AND DAYOFMONTH('.$this->date_field.')='.$date[CDAY];
}
}
return $res;
}
//--------------------------------------------------------- private members ---
function build_nav_bar2($view_type, $requested, $level, $sql_func, $labels=null)
function get_display_name()
{
parent::build_nav_bar($view_type, $requested, $level, $sql_func, '', $labels);
global $conf, $lang;
$res = '';
$url = $this->url_base;
if ( isset($this->date_components[CYEAR]) )
{
$res .= $conf['level_separator'];
$url .= $this->date_components[CYEAR].'-';
$res .=
'<a href="'.$url.'">'
.$this->get_date_component_label($this->date_components[CYEAR])
.'</a>';
}
if ( isset($this->date_components[CMONTH]) )
{
$res .= $conf['level_separator'];
$url .= $this->date_components[CMONTH].'-';
$res .=
'<a href="'.$url.'">'
.$this->get_date_component_label(
$this->date_components[CMONTH],
$lang['month']
)
.'</a>';
}
if ( isset($this->date_components[CDAY]) )
{
$res .= $conf['level_separator'];
$url .= $this->date_components[CDAY].'-';
$res .=
'<a href="'.$url.'">'
.$this->get_date_component_label($this->date_components[CDAY])
.'</a>';
}
return $res;
}
function build_global_calendar(&$requested)
//--------------------------------------------------------- private members ---
function build_nav_bar2($level, $sql_func, $labels=null)
{
assert( count($requested) == 0 );
parent::build_nav_bar($level, $sql_func, '', $labels);
}
function build_global_calendar()
{
assert( count($this->date_components) == 0 );
$query='SELECT DISTINCT(DATE_FORMAT('.$this->date_field.',"%Y%m")) as period,
COUNT(id) as count';
$query.= $this->inner_sql;
$query.= $this->get_date_where($requested);
$query.= $this->get_date_where();
$query.= '
GROUP BY period';
@ -175,14 +238,14 @@ function build_global_calendar(&$requested)
if (count($items)==1)
{// only one year exists so bail out to year view
list($y) = array_keys($items);
array_push($requested, $y );
$this->date_components[CYEAR] = $y;
return false;
}
global $lang, $template;
foreach ( $items as $year=>$year_data)
{
$url_base = $this->url_base .'c-'.$year;
$url_base = $this->url_base.$year;
$nav_bar = '<span class="calCalHead"><a href="'.$url_base.'">'.$year.'</a>';
$nav_bar .= ' ('.$year_data['nb_images'].')';
@ -199,13 +262,13 @@ function build_global_calendar(&$requested)
return true;
}
function build_year_calendar(&$requested)
function build_year_calendar()
{
assert( count($requested) == 1 );
assert( count($this->date_components) == 1 );
$query='SELECT DISTINCT(DATE_FORMAT('.$this->date_field.',"%m%d")) as period,
COUNT(id) as count';
$query.= $this->inner_sql;
$query.= $this->get_date_where($requested);
$query.= $this->get_date_where();
$query.= '
GROUP BY period';
@ -225,18 +288,18 @@ function build_year_calendar(&$requested)
if (count($items)==1)
{ // only one month exists so bail out to month view
list($m) = array_keys($items);
array_push($requested, $m );
$this->date_components[CMONTH] = $m;
if (count($items[$m]['children'])==1)
{ // or even to day view if everything occured in one day
list($d) = array_keys($items[$m]['children']);
array_push($requested, $d);
$this->date_components[CDAY] = $d;
}
return false;
}
global $lang, $template;
foreach ( $items as $month=>$month_data)
{
$url_base = $this->url_base.'c-'.$requested[0].'-'.$month;
$url_base = $this->url_base.$this->date_components[CYEAR].'-'.$month;
$nav_bar = '<span class="calCalHead"><a href="'.$url_base.'">';
$nav_bar .= $lang['month'][$month].'</a>';
@ -255,12 +318,12 @@ function build_year_calendar(&$requested)
}
function build_month_calendar($requested)
function build_month_calendar()
{
$query='SELECT DISTINCT(DATE_FORMAT('.$this->date_field.',"%d")) as period,
COUNT(id) as count';
$query.= $this->inner_sql;
$query.= $this->get_date_where($requested, 2);
$query.= $this->get_date_where($this->date_components);
$query.= '
GROUP BY period';
@ -277,15 +340,18 @@ function build_month_calendar($requested)
$template->assign_block_vars('thumbnails.line', array());
foreach ( $items as $day=>$nb_images)
{
$url_base = $this->url_base.'c-'.$requested[0].'-'.$requested[1].'-'.$day;
$requested[2]=$day;
$url_base = $this->url_base.
$this->date_components[CYEAR].'-'.
$this->date_components[CMONTH].'-'.$day;
$this->date_components[CDAY]=$day;
$query = '
SELECT file,tn_ext,path, DAYOFWEEK('.$this->date_field.')-1 as dw';
$query.= $this->inner_sql;
$query.= $this->get_date_where($requested);
$query.= $this->get_date_where();
$query.= '
ORDER BY RAND()
LIMIT 0,1';
unset ( $this->date_components[CDAY] );
$row = mysql_fetch_array(pwg_query($query));

View file

@ -26,6 +26,10 @@
include_once(PHPWG_ROOT_PATH.'include/calendar_base.class.php');
define ('CYEAR', 0);
define ('CWEEK', 1);
define ('CDAY', 2);
/**
* Weekly calendar style (composed of years/week in years and days in week)
*/
@ -36,52 +40,61 @@ class Calendar extends CalendarBase
* Generate navigation bars for category page
* @return boolean false to indicate that thumbnails where not included here
*/
function generate_category_content($url_base, $view_type, &$requested)
function generate_category_content($url_base, $view_type)
{
global $lang;
global $lang, $conf;
$this->url_base = $url_base;
assert($view_type==CAL_VIEW_LIST);
$this->build_nav_bar($view_type, $requested, 0, 'YEAR'); // years
if (count($requested)>0)
$this->build_nav_bar($view_type, $requested, 1, 'WEEK', '+1' ); // month
if (count($requested)>1)
$this->build_nav_bar($view_type, $requested, 2, 'DAYOFWEEK', '-1',
if ( $conf['calendar_multi_bar'] or count($this->date_components)==0 )
{
$this->build_nav_bar(CYEAR, 'YEAR'); // years
}
if ( count($this->date_components)>=1 and
( $conf['calendar_multi_bar'] or count($this->date_components)==1 )
)
{
$this->build_nav_bar(CWEEK, 'WEEK', '+1' ); // month
}
if ( count($this->date_components)>=2 )
{
$this->build_nav_bar(CDAY, 'DAYOFWEEK', '-1',
$lang['day'] ); // days
}
return false;
}
/**
* Returns a sql where subquery for the date field
* @param array requested selected levels for this calendar
* (e.g. 2005,42,1 for 41st week of 2005, Monday)
* @param int max_levels return the where up to this level
* (e.g. 2=only year and week in year)
* @return string
*/
function get_date_where($requested, $max_levels=3)
function get_date_where($max_levels=3)
{
while (count($requested)>$max_levels)
$date_components = $this->date_components;
while (count($date_components)>$max_levels)
{
array_pop($requested);
array_pop($date_components);
}
$res = '';
if (isset($requested[0]) and $requested[0]!='any')
if (isset($date_components[CYEAR]) and $date_components[CYEAR]!='any')
{
$y = $requested[0];
$y = $date_components[CYEAR];
$res = " AND $this->date_field BETWEEN '$y-01-01' AND '$y-12-31 23:59:59'";
}
if (isset($requested[1]) and $requested[1]!='any')
if (isset($date_components[CWEEK]) and $date_components[CWEEK]!='any')
{
$res .= ' AND WEEK('.$this->date_field.')+1='.$requested[1];
$res .= ' AND WEEK('.$this->date_field.')+1='.$date_components[CWEEK];
}
if (isset($requested[2]) and $requested[2]!='any')
if (isset($date_components[CDAY]) and $date_components[CDAY]!='any')
{
$res .= ' AND DAYOFWEEK('.$this->date_field.')-1='.$requested[2];
$res .= ' AND DAYOFWEEK('.$this->date_field.')-1='
.$date_components[CDAY];
}
if (empty($res))
{
@ -90,6 +103,44 @@ function get_date_where($requested, $max_levels=3)
return $res;
}
function get_display_name()
{
global $conf,$lang;
$res = '';
$url = $this->url_base;
if ( isset($this->date_components[CYEAR]) )
{
$res .= $conf['level_separator'];
$url .= $this->date_components[CYEAR].'-';
$res .=
'<a href="'.$url.'">'
.$this->get_date_component_label($this->date_components[CYEAR])
.'</a>';
}
if ( isset($this->date_components[CWEEK]) )
{
$res .= $conf['level_separator'];
$url .= $this->date_components[CWEEK].'-';
$res .=
'<a href="'.$url.'">'
.$this->get_date_component_label($this->date_components[CWEEK])
.'</a>';
}
if ( isset($this->date_components[CDAY]) )
{
$res .= $conf['level_separator'];
$url .= $this->date_components[CDAY].'-';
$res .=
'<a href="'.$url.'">'
.$this->get_date_component_label(
$this->date_components[CDAY],
$lang['day']
)
.'</a>';
}
return $res;
}
}
?>

View file

@ -90,6 +90,14 @@ $conf['anti-flood_time'] = 60;
// catgory
$conf['calendar_datefield'] = 'date_creation';
// calendar_multi_bar : the calendar shows a maximum number of
// year/month/week/day navigation bars
$conf['calendar_multi_bar'] = true;
// calendar_show_any : the calendar shows an aditional 'any' button in the
// year/month/week/day navigation bars
$conf['calendar_show_any'] = true;
// newcat_default_commentable : at creation, must a category be commentable
// or not ?
$conf['newcat_default_commentable'] = 'true';

View file

@ -27,6 +27,25 @@
define('CAL_VIEW_LIST', 'l');
define('CAL_VIEW_CALENDAR', 'c');
function get_calendar_parameter($options, &$parameters )
{
if ( count($parameters) and isset($options[$parameters[0]]) )
{
return array_shift($parameters);
}
else
{
foreach ($options as $option => $data)
{
if ( empty( $data['default_link'] ) )
{
break;
}
}
return $option;
}
}
function initialize_calendar()
{
global $page, $conf, $user, $template;
@ -73,65 +92,76 @@ WHERE id IN (' . implode(',',$page['items']) .')';
//-------------------------------------- initialize the calendar parameters ---
pwg_debug('start initialize_calendar');
// the parameters look like (FIELD)?(STYLE)?(VIEW)?(DATE COMPONENTS)?
// FIELD = (created-|posted-)
// STYLE = (m-|w-)
// VIEW = (l-|c-)
// DATE COMPONENTS= YEAR(-MONTH/WEEK)?(-DAY)?
$cal_styles = array(
$fields = array(
// Created
'created' => array(
// TODO change next line when calendar_datefield disapears
'default_link' => ( $conf['calendar_datefield']=='date_creation' ? '' : 'created-' ),
'label' => l10n('Creation date'),
'db_field' => 'date_creation',
),
// Posted
'posted' => array(
// TODO change next line when calendar_datefield disapears
'default_link' => ( $conf['calendar_datefield']=='date_available' ? '' : 'posted-' ),
'label' => l10n('Availability date'),
'db_field' => 'date_available',
),
);
$styles = array(
// Monthly style
array(
'link' => 'm',
'monthly' => array(
'default_link' => '',
'name' => l10n('Monthly'),
'label' => l10n('Monthly'),
'include' => 'calendar_monthly.class.php',
'view_calendar' => true,
),
// Weekly style
array(
'link' => 'w',
'default_link' => 'w-',
'name' => l10n('Weekly'),
'weekly' => array(
'default_link' => 'weekly-',
'label' => l10n('Weekly'),
'include' => 'calendar_weekly.class.php',
'view_calendar' => false,
),
);
$views = array(
// list view
CAL_VIEW_LIST => array(
'default_link' => '',
'label' => l10n('List')
),
// calendar view
CAL_VIEW_CALENDAR => array(
'default_link' => CAL_VIEW_CALENDAR.'-',
'label' => l10n('calendar')
),
);
$requested = explode('-', $_GET['calendar']);
$calendar = null;
foreach ($cal_styles as $cal_style)
{
if ($requested[0] == $cal_style['link'])
{
include(PHPWG_ROOT_PATH.'include/'.$cal_style['include']);
// Retrieve calendar field
$cal_field = get_calendar_parameter($fields, $requested);
// Retrieve style
$cal_style = get_calendar_parameter($styles, $requested);
include(PHPWG_ROOT_PATH.'include/'. $styles[$cal_style]['include']);
$calendar = new Calendar();
array_shift($requested);
break;
}
// Retrieve view
$cal_view = get_calendar_parameter($views, $requested);
if ( CAL_VIEW_CALENDAR==$cal_view and !$styles[$cal_style]['view_calendar'] )
{
$cal_view=CAL_VIEW_LIST;
}
if (!isset($calendar))
{
foreach($cal_styles as $cal_style)
{
if ('' == $cal_style['default_link'])
{
break;
}
}
include( PHPWG_ROOT_PATH.'include/'.$cal_style['include']);
$calendar = new Calendar();
}
$view_type = CAL_VIEW_LIST;
if ($requested[0] == CAL_VIEW_LIST)
{
array_shift($requested);
}
elseif ($requested[0] == CAL_VIEW_CALENDAR)
{
if ($cal_style['view_calendar'])
{
$view_type = CAL_VIEW_CALENDAR;
}
array_shift($requested);
}
// perform a sanity check on $requested
while (count($requested) > 3)
{
@ -143,7 +173,7 @@ WHERE id IN (' . implode(',',$page['items']) .')';
{
if ($requested[$i] == 'any')
{
if ($view_type == CAL_VIEW_CALENDAR)
if ($cal_view == CAL_VIEW_CALENDAR)
{// we dont allow any in calendar view
while ($i < count($requested))
{
@ -166,28 +196,25 @@ WHERE id IN (' . implode(',',$page['items']) .')';
array_pop($requested);
}
$calendar->initialize($conf['calendar_datefield'], $inner_sql);
//echo ('<pre>'. var_export($requested, true) . '</pre>');
//echo ('<pre>'. var_export($calendar, true) . '</pre>');
$calendar->initialize($fields[$cal_field]['db_field'], $inner_sql, $requested);
// TODO: what makes the list view required?
$must_show_list = true;
if (basename($_SERVER["PHP_SELF"]) == 'category.php')
{
$template->assign_block_vars('calendar', array());
//echo ('<pre>'. var_export($fields, true) . '</pre>');
$url_base =
PHPWG_ROOT_PATH.'category.php'
.get_query_string_diff(array('start', 'calendar'))
.(empty($url_base) ? '?' : '&')
.'calendar='
.'calendar='.$cal_field.'-'
;
$must_show_list = true; // true until calendar generates its own display
if (basename($_SERVER["PHP_SELF"]) == 'category.php')
{
$template->assign_block_vars('calendar', array());
if ($calendar->generate_category_content(
$url_base.$cal_style['default_link'],
$view_type,
$requested
$url_base.$cal_style.'-'.$cal_view.'-',
$cal_view
)
)
{
@ -200,81 +227,59 @@ WHERE id IN (' . implode(',',$page['items']) .')';
$must_show_list = false;
}
if ($cal_style['view_calendar'])
{ // Build bar for views (List/Calendar)
$views = array(
// list view
array(
'type' => CAL_VIEW_LIST,
'label' => l10n('List')
),
// calendar view
array(
'type' => CAL_VIEW_CALENDAR,
'label' => l10n('calendar')
),
);
$views_bar = '';
foreach ($views as $view)
$template->assign_block_vars( 'calendar.views', array() );
foreach ($styles as $style => $style_data)
{
if ($view_type != $view['type'])
foreach ($views as $view => $view_data)
{
$views_bar.=
'<a href="'
.$url_base.$cal_style['default_link'].$view['type'].'-'
.implode('-', $requested)
.'">'.$view['label'].'</a> ';
if ( $style_data['view_calendar'] or $view != CAL_VIEW_CALENDAR)
{
$selected = '';
$url = $url_base.$style.'-'.$view;
if ($style==$cal_style)
{
$url .= '-'.implode('-', $calendar->date_components);
if ( $view==$cal_view )
{
$selected = 'SELECTED';
}
}
else
{
$views_bar.= $view['label'].' ';
}
$views_bar.= ' ';
}
$template->assign_block_vars(
'calendar.views',
array(
'BAR' => $views_bar,
)
);
}
// Build bar for calendar styles (Monthly, Weekly)
$styles_bar = '';
foreach ($cal_styles as $style)
if (isset($calendar->date_components[0]))
{
if ($cal_style['link'] != $style['link'])
{
$url = $url_base.$style['default_link'];
$url .= $view_type;
if (isset($requested[0]))
{
$url .= '-' . $requested[0];
}
$styles_bar .= '<a href="'. $url . '">'.$style['name'].'</a> ';
}
else
{
$styles_bar .= $style['name'].' ';
$url .= '-' . $calendar->date_components[0];
}
}
$template->assign_block_vars(
'calendar.styles',
'calendar.views.view',
array(
'BAR' => $styles_bar,
'VALUE' => $url,
'CONTENT' => $style_data['label'].' ('.$view_data['label'].')',
'SELECTED' => $selected,
)
);
}
}
}
} // end category calling
$calendar_title =
'<a href="'.$url_base.$cal_style.'-'.$cal_view.'">'
.$fields[$cal_field]['label'].'</a>';
$calendar_title.= $calendar->get_display_name();
$template->assign_block_vars(
'calendar',
array(
'TITLE' => $calendar_title,
)
);
if ($must_show_list)
{
$query = 'SELECT DISTINCT(id)';
$query .= $calendar->inner_sql;
$query .= $calendar->get_date_where($requested);
$query .= $calendar->get_date_where();
if ( isset($page['super_order_by']) )
{
$query .= '

View file

@ -793,16 +793,9 @@ else
if (!empty($picture['current']['date_creation']))
{
$val = format_date($picture['current']['date_creation']);
if ( $conf['calendar_datefield'] == 'date_creation' )
{
$infos['INFO_CREATION_DATE'] = '<a href="'.
PHPWG_ROOT_PATH.'category.php?calendar=c-'.
PHPWG_ROOT_PATH.'category.php?calendar=created-c-'.
$picture['current']['date_creation'].'">'.$val.'</a>';
}
else
{
$infos['INFO_CREATION_DATE'] = $val;
}
}
else
{
@ -811,16 +804,9 @@ else
// date of availability
$val = format_date($picture['current']['date_available'], 'mysql_datetime');
if ( $conf['calendar_datefield'] == 'date_available' )
{
$infos['INFO_AVAILABILITY_DATE'] = '<a href="'.
PHPWG_ROOT_PATH.'category.php?calendar=c-'.
$infos['INFO_AVAILABILITY_DATE'] = '<a href="'.
PHPWG_ROOT_PATH.'category.php?calendar=posted-c-'.
substr($picture['current']['date_available'],0,10).'">'.$val.'</a>';
}
else
{
$infos['INFO_AVAILABILITY_DATE'] = $val;
}
// size in pixels
if ($picture['current']['is_picture'])

View file

@ -138,19 +138,23 @@
<!-- END normal_view -->
</ul>
<h2>{TITLE}</h2>
<h2>{TITLE}
<!-- BEGIN calendar -->
<br/>{calendar.TITLE}
<!-- END calendar --></h2>
</div> <!-- content -->
<!-- BEGIN calendar -->
<!-- BEGIN styles -->
<div class="calendarStyles">Style: {calendar.styles.BAR}</div>
<!-- END styles -->
<!-- BEGIN views -->
<div class="calendarViews">{calendar.views.BAR}</div>
<div class="calendarViews">
<select onchange="document.location = this.options[this.selectedIndex].value;">
<!-- BEGIN view -->
<option value="{calendar.views.view.VALUE}" {calendar.views.view.SELECTED}>{calendar.views.view.CONTENT}</option>
<!-- END view -->
</select>
</div><br/>
<!-- END views -->
<br/>
<!-- BEGIN navbar -->
<div class="navigationBar">{calendar.navbar.BAR}</div>
<!-- END navbar -->

View file

@ -179,12 +179,8 @@ SPAN.filename:after {
}
#content DIV.calendarStyles {
float: left;
}
#content DIV.calendarViews {
float: right;
float: left;
}
SPAN.cal {