2012-05-21 14:58:26 +12:00
|
|
|
<?php
|
2013-08-15 09:21:07 +12:00
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
if(class_exists('Widget')) {
|
2013-08-15 09:21:07 +12:00
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
/**
|
|
|
|
* Shows a widget with viewing blog entries
|
|
|
|
* by months or years.
|
|
|
|
*
|
|
|
|
* @package blog
|
|
|
|
*/
|
|
|
|
class ArchiveWidget extends Widget {
|
2013-08-15 09:21:07 +12:00
|
|
|
|
|
|
|
private static $db = array(
|
2013-04-11 12:35:22 +02:00
|
|
|
'DisplayMode' => 'Varchar'
|
2012-05-21 14:58:26 +12:00
|
|
|
);
|
|
|
|
|
2013-08-15 09:21:07 +12:00
|
|
|
private static $defaults = array(
|
2013-04-11 12:35:22 +02:00
|
|
|
'DisplayMode' => 'month'
|
|
|
|
);
|
|
|
|
|
2013-08-15 09:21:07 +12:00
|
|
|
private static $title = 'Browse by Date';
|
|
|
|
|
|
|
|
private static $cmsTitle = 'Blog Archive';
|
2012-05-21 14:58:26 +12:00
|
|
|
|
2013-08-15 09:21:07 +12:00
|
|
|
private static $description =
|
|
|
|
'Show a list of months or years in which there are blog posts, and provide links to them.';
|
2012-05-21 14:58:26 +12:00
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
function getCMSFields() {
|
|
|
|
$fields = parent::getCMSFields();
|
|
|
|
|
|
|
|
$fields->merge(
|
2012-05-21 15:58:40 +12:00
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
new FieldList(
|
|
|
|
new OptionsetField(
|
|
|
|
'DisplayMode',
|
|
|
|
_t('ArchiveWidget.DispBY', 'Display by'),
|
|
|
|
array(
|
|
|
|
'month' => _t('ArchiveWidget.MONTH', 'month'),
|
|
|
|
'year' => _t('ArchiveWidget.YEAR', 'year')
|
|
|
|
)
|
2012-05-21 14:58:26 +12:00
|
|
|
)
|
2013-04-11 12:35:22 +02:00
|
|
|
)
|
2012-05-21 14:58:26 +12:00
|
|
|
);
|
2013-04-11 12:35:22 +02:00
|
|
|
|
|
|
|
$this->extend('updateCMSFields', $fields);
|
|
|
|
|
|
|
|
return $fields;
|
2012-05-21 14:58:26 +12:00
|
|
|
}
|
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
function getDates() {
|
|
|
|
Requirements::themedCSS('archivewidget');
|
2012-05-21 14:58:26 +12:00
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
$results = new ArrayList();
|
|
|
|
$container = BlogTree::current();
|
|
|
|
$ids = $container->BlogHolderIDs();
|
2012-05-21 14:58:26 +12:00
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
$stage = Versioned::current_stage();
|
|
|
|
$suffix = (!$stage || $stage == 'Stage') ? "" : "_$stage";
|
|
|
|
|
2013-08-15 09:21:07 +12:00
|
|
|
if(method_exists(DB::getConn(), 'formattedDatetimeClause')) {
|
|
|
|
$monthclause = DB::getConn()->formattedDatetimeClause('"Date"', '%m');
|
|
|
|
$yearclause = DB::getConn()->formattedDatetimeClause('"Date"', '%Y');
|
|
|
|
} else {
|
|
|
|
$monthclause = 'MONTH("Date")';
|
|
|
|
$yearclause = 'YEAR("Date")';
|
|
|
|
}
|
2012-05-21 14:58:26 +12:00
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
if($this->DisplayMode == 'month') {
|
|
|
|
$sqlResults = DB::query("
|
2013-08-15 09:21:07 +12:00
|
|
|
SELECT DISTINCT CAST($monthclause AS " . DB::getConn()->dbDataType('unsigned integer') . ")
|
2014-05-08 10:54:32 +01:00
|
|
|
AS Month,
|
|
|
|
$yearclause AS Year
|
|
|
|
FROM SiteTree$suffix INNER JOIN BlogEntry$suffix
|
|
|
|
ON SiteTree$suffix.ID = BlogEntry$suffix.ID
|
|
|
|
WHERE SiteTree$suffix.ParentID IN (" . implode(', ', $ids) . ")
|
|
|
|
ORDER BY Year DESC, Month DESC;"
|
2013-04-11 12:35:22 +02:00
|
|
|
);
|
2012-05-21 14:58:26 +12:00
|
|
|
} else {
|
2013-04-11 12:35:22 +02:00
|
|
|
$sqlResults = DB::query("
|
2014-05-08 10:54:32 +01:00
|
|
|
SELECT DISTINCT $yearclause AS Year
|
|
|
|
FROM SiteTree$suffix INNER JOIN BlogEntry$suffix
|
|
|
|
ON SiteTree$suffix.ID = BlogEntry$suffix.ID
|
|
|
|
WHERE SiteTree$suffix.ParentID IN (" . implode(', ', $ids) . ")
|
|
|
|
ORDER BY Year DESC"
|
2013-04-11 12:35:22 +02:00
|
|
|
);
|
2012-05-21 14:58:26 +12:00
|
|
|
}
|
|
|
|
|
2013-04-11 12:35:22 +02:00
|
|
|
if($sqlResults) foreach($sqlResults as $sqlResult) {
|
|
|
|
$isMonthDisplay = $this->DisplayMode == 'month';
|
|
|
|
|
|
|
|
$monthVal = (isset($sqlResult['Month'])) ? (int) $sqlResult['Month'] : 1;
|
|
|
|
$month = ($isMonthDisplay) ? $monthVal : 1;
|
|
|
|
$year = ($sqlResult['Year']) ? (int) $sqlResult['Year'] : date('Y');
|
|
|
|
|
|
|
|
$date = DBField::create_field('Date', array(
|
|
|
|
'Day' => 1,
|
|
|
|
'Month' => $month,
|
|
|
|
'Year' => $year
|
|
|
|
));
|
|
|
|
|
|
|
|
if($isMonthDisplay) {
|
|
|
|
$link = $container->Link('date') . '/' . $sqlResult['Year'] . '/' . sprintf("%'02d", $monthVal);
|
|
|
|
} else {
|
|
|
|
$link = $container->Link('date') . '/' . $sqlResult['Year'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$results->push(new ArrayData(array(
|
|
|
|
'Date' => $date,
|
|
|
|
'Link' => $link
|
|
|
|
)));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $results;
|
|
|
|
}
|
|
|
|
}
|
2012-05-21 14:58:26 +12:00
|
|
|
|
2013-08-15 09:21:07 +12:00
|
|
|
}
|