2014-02-20 06:05:14 +01:00
|
|
|
<?php
|
|
|
|
|
2017-09-06 05:49:23 +02:00
|
|
|
namespace SilverStripe\ContentReview\Extensions;
|
|
|
|
|
|
|
|
use SilverStripe\Core\Config\Config;
|
|
|
|
use SilverStripe\Control\Email\Email;
|
|
|
|
use SilverStripe\Forms\DropdownField;
|
|
|
|
use SilverStripe\Forms\FieldList;
|
|
|
|
use SilverStripe\Forms\ListboxField;
|
|
|
|
use SilverStripe\Forms\LiteralField;
|
|
|
|
use SilverStripe\Forms\TextareaField;
|
|
|
|
use SilverStripe\Forms\TextField;
|
|
|
|
use SilverStripe\ORM\DataExtension;
|
|
|
|
use SilverStripe\Security\Group;
|
|
|
|
use SilverStripe\Security\Member;
|
|
|
|
use SilverStripe\Security\Permission;
|
|
|
|
|
2014-02-20 06:05:14 +01:00
|
|
|
/**
|
2015-11-02 00:27:42 +01:00
|
|
|
* This extensions add a default schema for new pages and pages without a content
|
|
|
|
* review setting.
|
|
|
|
*
|
|
|
|
* @property int $ReviewPeriodDays
|
2014-02-20 06:05:14 +01:00
|
|
|
*/
|
2015-11-02 00:27:42 +01:00
|
|
|
class ContentReviewDefaultSettings extends DataExtension
|
|
|
|
{
|
|
|
|
/**
|
2015-11-17 02:17:54 +01:00
|
|
|
* @config
|
|
|
|
*
|
2015-11-02 00:27:42 +01:00
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private static $db = array(
|
2015-11-17 02:17:54 +01:00
|
|
|
'ReviewPeriodDays' => 'Int',
|
|
|
|
'ReviewFrom' => 'Varchar(255)',
|
|
|
|
'ReviewSubject' => 'Varchar(255)',
|
|
|
|
'ReviewBody' => 'HTMLText',
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @config
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private static $defaults = array(
|
|
|
|
'ReviewSubject' => 'Page(s) are due for content review',
|
|
|
|
'ReviewBody' => '<h2>Page(s) due for review</h2><p>There are $PagesCount pages that are due for review today by you.</p>',
|
2015-11-02 00:27:42 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2015-11-17 02:17:54 +01:00
|
|
|
* @config
|
2015-11-02 00:27:42 +01:00
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
private static $many_many = array(
|
2017-09-06 05:49:23 +02:00
|
|
|
'ContentReviewGroups' => Group::class,
|
|
|
|
'ContentReviewUsers' => Member::class,
|
2015-11-02 00:27:42 +01:00
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2015-11-17 02:17:54 +01:00
|
|
|
* Template to use for content review emails.
|
2015-11-02 00:27:42 +01:00
|
|
|
*
|
2015-11-17 02:17:54 +01:00
|
|
|
* This should contain an $EmailBody variable as a placeholder for the user-defined copy
|
|
|
|
*
|
|
|
|
* @config
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2017-09-06 05:49:23 +02:00
|
|
|
private static $content_review_template = 'SilverStripe\\ContentReview\\ContentReviewEmail';
|
2015-11-17 02:17:54 +01:00
|
|
|
|
|
|
|
/**
|
2015-11-02 00:27:42 +01:00
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getOwnerNames()
|
|
|
|
{
|
|
|
|
$names = array();
|
|
|
|
|
|
|
|
foreach ($this->OwnerGroups() as $group) {
|
2015-11-17 02:17:54 +01:00
|
|
|
$names[] = $group->getBreadcrumbs(' > ');
|
2015-11-02 00:27:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($this->OwnerUsers() as $group) {
|
|
|
|
$names[] = $group->getName();
|
|
|
|
}
|
|
|
|
|
2015-11-17 02:17:54 +01:00
|
|
|
return implode(', ', $names);
|
2015-11-02 00:27:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return ManyManyList
|
|
|
|
*/
|
|
|
|
public function OwnerGroups()
|
|
|
|
{
|
2015-11-17 02:17:54 +01:00
|
|
|
return $this->owner->getManyManyComponents('ContentReviewGroups');
|
2015-11-02 00:27:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return ManyManyList
|
|
|
|
*/
|
|
|
|
public function OwnerUsers()
|
|
|
|
{
|
2015-11-17 02:17:54 +01:00
|
|
|
return $this->owner->getManyManyComponents('ContentReviewUsers');
|
2015-11-02 00:27:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param FieldList $fields
|
|
|
|
*/
|
|
|
|
public function updateCMSFields(FieldList $fields)
|
|
|
|
{
|
2015-11-17 02:17:54 +01:00
|
|
|
$helpText = LiteralField::create(
|
|
|
|
'ContentReviewHelp',
|
|
|
|
_t(
|
2018-01-08 21:53:59 +01:00
|
|
|
__CLASS__ . '.DEFAULTSETTINGSHELP',
|
2017-08-23 00:02:37 +02:00
|
|
|
'These settings will apply to all pages that do not have a specific Content Review schedule.'
|
2015-11-17 02:17:54 +01:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$fields->addFieldToTab('Root.ContentReview', $helpText);
|
|
|
|
|
|
|
|
$reviewFrequency = DropdownField::create(
|
|
|
|
'ReviewPeriodDays',
|
2018-01-08 21:53:59 +01:00
|
|
|
_t(__CLASS__ . '.REVIEWFREQUENCY', 'Review frequency'),
|
2015-11-17 02:17:54 +01:00
|
|
|
SiteTreeContentReview::get_schedule()
|
|
|
|
)
|
|
|
|
->setDescription(_t(
|
2018-01-08 21:53:59 +01:00
|
|
|
__CLASS__ . '.REVIEWFREQUENCYDESCRIPTION',
|
2017-08-23 00:02:37 +02:00
|
|
|
'The review date will be set to this far in the future, whenever the page is published.'
|
2015-11-17 02:17:54 +01:00
|
|
|
));
|
|
|
|
|
|
|
|
$fields->addFieldToTab('Root.ContentReview', $reviewFrequency);
|
2015-11-02 00:27:42 +01:00
|
|
|
|
|
|
|
$users = Permission::get_members_by_permission(array(
|
2015-11-17 02:17:54 +01:00
|
|
|
'CMS_ACCESS_CMSMain',
|
|
|
|
'ADMIN',
|
2015-11-02 00:27:42 +01:00
|
|
|
));
|
|
|
|
|
2015-11-17 02:17:54 +01:00
|
|
|
$usersMap = $users->map('ID', 'Title')->toArray();
|
2015-11-02 00:27:42 +01:00
|
|
|
asort($usersMap);
|
|
|
|
|
2018-01-08 21:53:59 +01:00
|
|
|
$userField = ListboxField::create('OwnerUsers', _t(__CLASS__ . '.PAGEOWNERUSERS', 'Users'), $usersMap)
|
|
|
|
->setAttribute('data-placeholder', _t(__CLASS__ . '.ADDUSERS', 'Add users'))
|
|
|
|
->setDescription(_t(__CLASS__ . '.OWNERUSERSDESCRIPTION', 'Page owners that are responsible for reviews'));
|
2015-11-02 00:27:42 +01:00
|
|
|
|
2015-11-17 02:17:54 +01:00
|
|
|
$fields->addFieldToTab('Root.ContentReview', $userField);
|
2015-11-02 00:27:42 +01:00
|
|
|
|
|
|
|
$groupsMap = array();
|
|
|
|
|
|
|
|
foreach (Group::get() as $group) {
|
|
|
|
// Listboxfield values are escaped, use ASCII char instead of »
|
2015-11-17 02:17:54 +01:00
|
|
|
$groupsMap[$group->ID] = $group->getBreadcrumbs(' > ');
|
2015-11-02 00:27:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
asort($groupsMap);
|
|
|
|
|
2018-01-08 21:53:59 +01:00
|
|
|
$groupField = ListboxField::create('OwnerGroups', _t(__CLASS__ . '.PAGEOWNERGROUPS', 'Groups'), $groupsMap)
|
|
|
|
->setAttribute('data-placeholder', _t(__CLASS__ . '.ADDGROUP', 'Add groups'))
|
|
|
|
->setDescription(_t(__CLASS__ . '.OWNERGROUPSDESCRIPTION', 'Page owners that are responsible for reviews'));
|
2015-11-17 02:17:54 +01:00
|
|
|
|
|
|
|
$fields->addFieldToTab('Root.ContentReview', $groupField);
|
|
|
|
|
|
|
|
// Email content
|
|
|
|
$fields->addFieldsToTab(
|
|
|
|
'Root.ContentReview',
|
|
|
|
array(
|
2018-01-08 21:53:59 +01:00
|
|
|
TextField::create('ReviewFrom', _t(__CLASS__ . '.EMAILFROM', 'From email address'))
|
|
|
|
->setDescription(_t(__CLASS__ . '.EMAILFROM_RIGHTTITLE', 'e.g: do-not-reply@site.com')),
|
|
|
|
TextField::create('ReviewSubject', _t(__CLASS__ . '.EMAILSUBJECT', 'Subject line')),
|
|
|
|
TextAreaField::create('ReviewBody', _t(__CLASS__ . '.EMAILTEMPLATE', 'Email template')),
|
2017-09-06 05:49:23 +02:00
|
|
|
LiteralField::create(
|
|
|
|
'TemplateHelp',
|
|
|
|
$this->owner->renderWith('SilverStripe\\ContentReview\\ContentReviewAdminHelp')
|
|
|
|
),
|
2015-11-17 02:17:54 +01:00
|
|
|
)
|
|
|
|
);
|
2015-11-02 00:27:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all Members that are default Content Owners. This includes checking group hierarchy
|
|
|
|
* and adding any direct users.
|
|
|
|
*
|
|
|
|
* @return ArrayList
|
|
|
|
*/
|
2015-11-17 02:17:54 +01:00
|
|
|
public function ContentReviewOwners()
|
|
|
|
{
|
2015-11-02 00:27:42 +01:00
|
|
|
return SiteTreeContentReview::merge_owners($this->OwnerGroups(), $this->OwnerUsers());
|
|
|
|
}
|
2015-11-17 02:17:54 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the review body, falling back to the default if left blank.
|
|
|
|
*
|
|
|
|
* @return string HTML text
|
|
|
|
*/
|
|
|
|
public function getReviewBody()
|
|
|
|
{
|
|
|
|
return $this->getWithDefault('ReviewBody');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the review subject line, falling back to the default if left blank.
|
|
|
|
*
|
|
|
|
* @return string plain text value
|
|
|
|
*/
|
|
|
|
public function getReviewSubject()
|
|
|
|
{
|
|
|
|
return $this->getWithDefault('ReviewSubject');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the "from" field for review emails.
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getReviewFrom()
|
|
|
|
{
|
|
|
|
$from = $this->owner->getField('ReviewFrom');
|
|
|
|
if ($from) {
|
|
|
|
return $from;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fall back to admin email
|
2017-09-06 05:49:23 +02:00
|
|
|
return Config::inst()->get(Email::class, 'admin_email');
|
2015-11-17 02:17:54 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the value of a user-configured field, falling back to the default if left blank.
|
|
|
|
*
|
|
|
|
* @param string $field
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
protected function getWithDefault($field)
|
|
|
|
{
|
|
|
|
$value = $this->owner->getField($field);
|
|
|
|
if ($value) {
|
|
|
|
return $value;
|
|
|
|
}
|
|
|
|
// fallback to default value
|
2017-09-06 05:49:23 +02:00
|
|
|
$defaults = $this->owner->config()->get('defaults');
|
2015-11-17 02:17:54 +01:00
|
|
|
if (isset($defaults[$field])) {
|
|
|
|
return $defaults[$field];
|
|
|
|
}
|
|
|
|
}
|
2014-02-20 06:05:14 +01:00
|
|
|
}
|