silverstripe-blog/src/Widgets/BlogArchiveWidget.php

149 lines
3.9 KiB
PHP
Raw Normal View History

2015-11-21 19:17:29 +13:00
<?php
namespace SilverStripe\Blog\Widgets;
use SilverStripe\Blog\Model\Blog;
use SilverStripe\Control\Controller;
use SilverStripe\Forms\DropdownField;
use SilverStripe\Forms\NumericField;
2017-09-14 17:11:45 +12:00
use SilverStripe\ORM\ArrayList;
use SilverStripe\ORM\DB;
use SilverStripe\ORM\FieldType\DBDate;
use SilverStripe\ORM\FieldType\DBDatetime;
use SilverStripe\ORM\Queries\SQLSelect;
use SilverStripe\Versioned\Versioned;
use SilverStripe\View\ArrayData;
use SilverStripe\Widgets\Model\Widget;
2017-09-27 11:48:41 +13:00
if (!class_exists(Widget::class)) {
2015-11-21 19:17:29 +13:00
return;
}
/**
* @method Blog Blog()
*
* @property string $ArchiveType
* @property int $NumberToDisplay
*/
class BlogArchiveWidget extends Widget
{
/**
* @var string
*/
private static $title = 'Archive';
/**
* @var string
*/
private static $cmsTitle = 'Archive';
/**
* @var string
*/
private static $description = 'Displays an archive list of posts.';
/**
* @var array
*/
2017-09-14 10:59:01 +12:00
private static $db = [
2015-11-21 19:17:29 +13:00
'NumberToDisplay' => 'Int',
'ArchiveType' => 'Enum(\'Monthly,Yearly\', \'Monthly\')',
2017-09-14 10:59:01 +12:00
];
2015-11-21 19:17:29 +13:00
/**
* @var array
*/
2017-09-14 10:59:01 +12:00
private static $defaults = [
2015-11-21 19:17:29 +13:00
'NumberOfMonths' => 12,
2017-09-14 10:59:01 +12:00
];
2015-11-21 19:17:29 +13:00
/**
* @var array
*/
2017-09-14 10:59:01 +12:00
private static $has_one = [
'Blog' => Blog::class,
2017-09-14 10:59:01 +12:00
];
2015-11-21 19:17:29 +13:00
/**
* {@inheritdoc}
*/
public function getCMSFields()
{
$this->beforeUpdateCMSFields(function ($fields) {
2015-11-21 19:17:29 +13:00
/**
* @var Enum $archiveType
*/
$archiveType = $this->dbObject('ArchiveType');
2015-11-21 19:17:29 +13:00
$type = $archiveType->enumValues();
foreach ($type as $k => $v) {
2017-09-14 10:27:40 +12:00
$type[$k] = _t(__CLASS__ .'.' . ucfirst(strtolower($v)), $v);
2015-11-21 19:17:29 +13:00
}
/**
* @var FieldList $fields
*/
2017-09-14 10:59:01 +12:00
$fields->merge([
DropdownField::create(
'BlogID',
2017-09-14 10:27:40 +12:00
_t(__CLASS__ . '.Blog', 'Blog'),
Blog::get()->map()
),
2017-09-14 10:27:40 +12:00
DropdownField::create('ArchiveType', _t(__CLASS__ . '.ArchiveType', 'ArchiveType'), $type),
NumericField::create('NumberToDisplay', _t(__CLASS__ . '.NumberToDisplay', 'No. to Display'))
2017-09-14 10:59:01 +12:00
]);
2015-11-21 19:17:29 +13:00
});
return parent::getCMSFields();
}
/**
* Returns a list of months where blog posts are present.
*
* @return ArrayList
2015-11-21 19:17:29 +13:00
*/
public function getArchive()
{
$format = ($this->ArchiveType == 'Yearly') ? '%Y' : '%Y-%m';
$publishDate = DB::get_conn()->formattedDatetimeClause('"PublishDate"', $format);
2017-09-14 17:11:45 +12:00
$fields = [
'PublishDate' => $publishDate,
'Total' => "COUNT('\"PublishDate\"')"
2017-09-14 17:11:45 +12:00
];
2017-09-14 17:11:45 +12:00
$stage = Versioned::get_stage();
2017-09-27 11:48:41 +13:00
$suffix = ($stage === Versioned::LIVE) ? '_' . Versioned::LIVE : '';
$query = SQLSelect::create($fields, '"BlogPost' . $suffix . '"')
->addGroupBy($publishDate)
->addOrderBy('"PublishDate" DESC')
2017-09-27 11:48:41 +13:00
->addWhere(['"PublishDate" < ?' => DBDatetime::now()->getISOFormat()]);
$posts = $query->execute();
2017-09-14 17:11:45 +12:00
$result = ArrayList::create();
while ($next = $posts->next()) {
if ($this->ArchiveType == 'Yearly') {
$year = $next['PublishDate'];
$month = null;
$title = $year;
} else {
$date = Date::create();
$date->setValue(strtotime($next['PublishDate']));
$year = $date->Format('Y');
$month = $date->Format('m');
$title = $date->FormatI18N('%B %Y');
2015-11-21 19:17:29 +13:00
}
2017-09-14 17:11:45 +12:00
$result->push(ArrayData::create([
'Title' => $title,
'Link' => Controller::join_links($this->Blog()->Link('archive'), $year, $month)
2017-09-14 17:11:45 +12:00
]));
2015-11-21 19:17:29 +13:00
}
$this->extend('updateGetArchive', $result);
2017-09-26 16:15:57 +13:00
return $result;
2015-11-21 19:17:29 +13:00
}
}