'Int', 'ReviewFrom' => 'Varchar(255)', 'ReviewSubject' => 'Varchar(255)', 'ReviewSubjectFirstReminder' => 'Varchar(255)', 'ReviewSubjectSecondReminder' => 'Varchar(255)', 'ReviewBody' => 'HTMLText', 'ReviewBodyFirstReminder' => 'HTMLText', 'ReviewBodySecondReminder' => 'HTMLText', 'FirstReviewDaysBefore' => 'Int', 'SecondReviewDaysBefore' => 'Int' ); /** * @config * * @var array */ private static $defaults = array( 'ReviewSubjectFirstReminder' => 'Page(s) are 1 month from content review', 'ReviewSubjectSecondReminder' => 'Page(s) are 1 week from content review', 'ReviewSubject' => 'Page(s) are due for content review', 'ReviewBodyFirstReminder' => '
There are $PagesCount pages that are due for review by you 1 month from today.
', 'ReviewBodySecondReminder' => 'There are $PagesCount pages that are due for review by you 1 week from today.
', 'ReviewBody' => 'There are $PagesCount pages that are due for review today by you.
', 'FirstReviewDaysBefore' => '30', 'SecondReviewDaysBefore' => '7' ); /** * @config * * @var array */ private static $many_many = array( 'ContentReviewGroups' => 'Group', 'ContentReviewUsers' => 'Member', ); /** * Template to use for content review emails. * * This should contain an $EmailBody variable as a placeholder for the user-defined copy * * @config * * @var string */ private static $content_review_template = 'ContentReviewEmail'; /** * @return string */ public function getOwnerNames() { $names = array(); foreach ($this->OwnerGroups() as $group) { $names[] = $group->getBreadcrumbs(' > '); } foreach ($this->OwnerUsers() as $group) { $names[] = $group->getName(); } return implode(', ', $names); } /** * @return ManyManyList */ public function OwnerGroups() { return $this->owner->getManyManyComponents('ContentReviewGroups'); } /** * @return ManyManyList */ public function OwnerUsers() { return $this->owner->getManyManyComponents('ContentReviewUsers'); } /** * @param FieldList $fields */ public function updateCMSFields(FieldList $fields) { $helpText = LiteralField::create( 'ContentReviewHelp', _t( 'ContentReview.DEFAULTSETTINGSHELP', 'These content review settings will apply to all pages that does not have specific Content Review schedule.' ) ); $fields->addFieldToTab('Root.ContentReview', $helpText); $reviewFrequency = DropdownField::create( 'ReviewPeriodDays', _t('ContentReview.REVIEWFREQUENCY', 'Review frequency'), SiteTreeContentReview::get_schedule() ) ->setDescription(_t( 'ContentReview.REVIEWFREQUENCYDESCRIPTION', 'The review date will be set to this far in the future whenever the page is published' )); $fields->addFieldToTab('Root.ContentReview', $reviewFrequency); $FirstReviewDaysBefore = NumericField::create( 'FirstReviewDaysBefore', _t('ContentReview.FIRSTREVIEWDAYSBEFORE', 'First review reminder # days before final review') ); $fields->addFieldToTab('Root.ContentReview', $FirstReviewDaysBefore); $SecondReviewDaysBefore = NumericField::create( 'SecondReviewDaysBefore', _t('ContentReview.SECONDREVIEWDAYSBEFORE', 'Second review reminder # days before final review') ); $fields->addFieldToTab('Root.ContentReview', $SecondReviewDaysBefore); $users = Permission::get_members_by_permission(array( 'CMS_ACCESS_CMSMain', 'ADMIN', )); $usersMap = $users->map('ID', 'Title')->toArray(); asort($usersMap); $userField = ListboxField::create('OwnerUsers', _t('ContentReview.PAGEOWNERUSERS', 'Users'), $usersMap) ->setMultiple(true) ->setAttribute('data-placeholder', _t('ContentReview.ADDUSERS', 'Add users')) ->setDescription(_t('ContentReview.OWNERUSERSDESCRIPTION', 'Page owners that are responsible for reviews')); $fields->addFieldToTab('Root.ContentReview', $userField); $groupsMap = array(); foreach (Group::get() as $group) { // Listboxfield values are escaped, use ASCII char instead of » $groupsMap[$group->ID] = $group->getBreadcrumbs(' > '); } asort($groupsMap); $groupField = ListboxField::create('OwnerGroups', _t('ContentReview.PAGEOWNERGROUPS', 'Groups'), $groupsMap) ->setMultiple(true) ->setAttribute('data-placeholder', _t('ContentReview.ADDGROUP', 'Add groups')) ->setDescription(_t('ContentReview.OWNERGROUPSDESCRIPTION', 'Page owners that are responsible for reviews')); $fields->addFieldToTab('Root.ContentReview', $groupField); // Email content $fields->addFieldsToTab( 'Root.ContentReview', array( TextField::create('ReviewFrom', _t('ContentReview.EMAILFROM', 'From email address')) ->setRightTitle(_t('Review.EMAILFROM_RIGHTTITLE', 'e.g: do-not-reply@site.com')), TextField::create('ReviewSubjectFirstReminder', _t('ContentReview.EMAILSUBJECTFIRSTREMINDER', 'Subject line - First reminder')), TextField::create('ReviewSubjectSecondReminder', _t('ContentReview.EMAILSUBJECTSECONDREMINDER', 'Subject line - Second reminder')), TextField::create('ReviewSubject', _t('ContentReview.EMAILSUBJECT', 'Subject line - Review due')), TextAreaField::create('ReviewBodyFirstReminder', _t('ContentReview.EMAILTEMPLATEFIRSTREMINDER', 'Email template - First reminder')), TextAreaField::create('ReviewBodySecondReminder', _t('ContentReview.EMAILTEMPLATESECONDREMINDER', 'Email template - Second reminder')), TextAreaField::create('ReviewBody', _t('ContentReview.EMAILTEMPLATE', 'Email template - Review due')), LiteralField::create('TemplateHelp', $this->owner->renderWith('ContentReviewAdminHelp')), ) ); } /** * Get all Members that are default Content Owners. This includes checking group hierarchy * and adding any direct users. * * @return ArrayList */ public function ContentReviewOwners() { return SiteTreeContentReview::merge_owners($this->OwnerGroups(), $this->OwnerUsers()); } /** * 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 return Config::inst()->get('Email', 'admin_email'); } /** * 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 $defaults = $this->owner->config()->defaults; if (isset($defaults[$field])) { return $defaults[$field]; } } }