FIX: include separate grid fields for unmoderated and moderated comments.

Extended GridField configuration to include pagination, searching and filtering of comments as well as deleting and editng.
This commit is contained in:
Will Rossiter 2012-07-22 12:47:59 +12:00
parent 235b309cae
commit 715576797f

View File

@ -7,15 +7,13 @@
*/ */
class CommentAdmin extends LeftAndMain { class CommentAdmin extends LeftAndMain {
static $url_segment = 'comments'; public static $url_segment = 'comments';
static $url_rule = '/$Action'; public static $url_rule = '/$Action';
static $menu_title = 'Comments'; public static $menu_title = 'Comments';
static $template_path = null; // defaults to (project)/templates/email public static $allowed_actions = array(
static $allowed_actions = array(
'approvedmarked', 'approvedmarked',
'deleteall', 'deleteall',
'deletemarked', 'deletemarked',
@ -27,52 +25,54 @@ class CommentAdmin extends LeftAndMain {
); );
/** /**
* @var int The number of comments per page for the {@link CommentTable} in this admin. * @return Form
*/ */
static $comments_per_page = 20;
public function init() {
parent::init();
//Requirements::javascript(CMS_DIR . '/javascript/CommentAdmin_right.js');
//Requirements::css(CMS_DIR . '/css/CommentAdmin.css');
}
public function getEditForm($id = null, $fields = null) { public function getEditForm($id = null, $fields = null) {
// TODO Duplicate record fetching (see parent implementation)
if(!$id) $id = $this->currentPageID(); if(!$id) $id = $this->currentPageID();
$form = parent::getEditForm($id); $form = parent::getEditForm($id);
// TODO Duplicate record fetching (see parent implementation)
$record = $this->getRecord($id); $record = $this->getRecord($id);
if($record && !$record->canView()) return Security::permissionFailure($this);
$commentList = GridField::create( if($record && !$record->canView()) {
return Security::permissionFailure($this);
}
$commentsConfig = GridFieldConfig::create()->addComponents(
new GridFieldFilterHeader(),
new GridFieldDataColumns(),
new GridFieldSortableHeader(),
new GridFieldPaginator(25),
new GridFieldDeleteAction(),
new GridFieldDetailForm(),
new GridFieldExportButton(),
new GridFieldEditButton(),
new GridFieldDetailForm()
);
$needs = new GridField(
'Comments', 'Comments',
false, _t('CommentsAdmin.NeedsModeration', 'Needs Moderation'),
Comment::get(), Comment::get()->where('NeedsModeration = 1'),
$commentListConfig = GridFieldConfig_RecordViewer::create() $commentsConfig
//->addComponent(new GridFieldExportButton()) );
)->addExtraClass("comments_grid");
//$commentListConfig->getComponentByType('GridFieldDetailForm')->setValidator(new Comment_Validator()); $moderated = new GridField(
'CommentsModerated',
_t('CommentsAdmin.CommentsModerated'),
Comment::get()->where('NeedsModeration = 0'),
$commentsConfig
);
$fields = new FieldList( $fields = new FieldList(
$root = new TabSet( $root = new TabSet(
'Root', 'Root',
$commentsTab = new Tab('Comments', _t('CommentAdmin.Comments', 'Comments'), new Tab('NeedsModeration', _t('CommentAdmin.NeedsModeration', 'Needs Moderation'),
$commentList// , $needs
// new HeaderField(_t('CommentAdmin.IMPORTCOMMENTS', 'Import comments'), 3), ),
// new LiteralField( new Tab('Comments', _t('CommentAdmin.Moderated', 'Moderated'),
// 'CommentImportFormIframe', $moderated
// sprintf(
// '<iframe src="%s" id="CommentImportFormIframe" width="100%%" height="250px" border="0"></iframe>',
// $this->Link('commentimport')
// )
// )
) )
), )
// necessary for tree node selection in LeftAndMain.EditForm.js
new HiddenField('ID', false, 0)
); );
$root->setTemplate('CMSTabSet'); $root->setTemplate('CMSTabSet');
@ -85,207 +85,17 @@ class CommentAdmin extends LeftAndMain {
$fields, $fields,
$actions $actions
); );
$form->addExtraClass('cms-edit-form'); $form->addExtraClass('cms-edit-form');
$form->setTemplate($this->getTemplatesWithSuffix('_EditForm')); $form->setTemplate($this->getTemplatesWithSuffix('_EditForm'));
if($form->Fields()->hasTabset()) $form->Fields()->findOrMakeTab('Root')->setTemplate('CMSTabSet');
$form->addExtraClass('center ss-tabset cms-tabset ' . $this->BaseCSSClasses()); if($form->Fields()->hasTabset()) {
$form->Fields()->findOrMakeTab('Root')->setTemplate('CMSTabSet');
$form->addExtraClass('center ss-tabset cms-tabset ' . $this->BaseCSSClasses());
}
$this->extend('updateEditForm', $form); $this->extend('updateEditForm', $form);
return $form; return $form;
} }
public function showtable($params) {
return $this->getLastFormIn($this->renderWith('CommentAdmin_right'));
}
public function Section() {
$url = rtrim($_SERVER['REQUEST_URI'], '/');
if(strrpos($url, '&')) {
$url = substr($url, 0, strrpos($url, '&'));
}
$section = substr($url, strrpos($url, '/') + 1);
if($section != 'approved' && $section != 'unmoderated' && $section != 'spam') {
$section = Session::get('CommentsSection');
}
if($section != 'approved' && $section != 'unmoderated' && $section != 'spam') {
$section = 'approved';
}
return $section;
}
function deletemarked() {
$numComments = 0;
$folderID = 0;
$deleteList = '';
if($_REQUEST['Comments']) {
foreach($_REQUEST['Comments'] as $commentid) {
$comment = DataObject::get_by_id('Comment', $commentid);
if($comment && $comment->canDelete()) {
$comment->delete();
$numComments++;
}
}
} else {
user_error("No comments in $commentList could be found!", E_USER_ERROR);
}
echo <<<JS
$deleteList
$('Form_EditForm').getPageFromServer($('Form_EditForm_ID').value);
statusMessage("Deleted $numComments comments.");
JS;
}
function deleteall() {
$numComments = 0;
$spam = DataObject::get('Comment', "\"Comment\".\"IsSpam\" = '1'");
if($spam) {
$numComments = $spam->Count();
foreach($spam as $comment) {
if($comment->canDelete()) {
$comment->delete();
}
}
}
$msg = sprintf(_t('CommentAdmin.DELETED', 'Deleted %s comments.'), $numComments);
echo <<<JS
$('Form_EditForm').getPageFromServer($('Form_EditForm_ID').value);
statusMessage("$msg");
JS;
}
function spammarked() {
$numComments = 0;
$folderID = 0;
$deleteList = '';
if($_REQUEST['Comments']) {
foreach($_REQUEST['Comments'] as $commentid) {
$comment = DataObject::get_by_id('Comment', $commentid);
if($comment) {
$comment->IsSpam = true;
$comment->Moderated = true;
$comment->write();
$numComments++;
}
}
} else {
user_error("No comments in $commentList could be found!", E_USER_ERROR);
}
$msg = sprintf(_t('CommentAdmin.MARKEDSPAM', 'Marked %s comments as spam.'), $numComments);
echo <<<JS
$deleteList
$('Form_EditForm').getPageFromServer($('Form_EditForm_ID').value);
statusMessage("$msg");
JS;
}
function hammarked() {
$numComments = 0;
$folderID = 0;
$deleteList = '';
if($_REQUEST['Comments']) {
foreach($_REQUEST['Comments'] as $commentid) {
$comment = DataObject::get_by_id('Comment', $commentid);
if($comment) {
$comment->IsSpam = false;
$comment->Moderated = true;
$comment->write();
$numComments++;
}
}
} else {
user_error("No comments in $commentList could be found!", E_USER_ERROR);
}
$msg = sprintf(_t('CommentAdmin.MARKEDNOTSPAM', 'Marked %s comments as not spam.'), $numComments);
echo <<<JS
$deleteList
$('Form_EditForm').getPageFromServer($('Form_EditForm_ID').value);
statusMessage("$msg");
JS;
}
function acceptmarked() {
$numComments = 0;
$folderID = 0;
$deleteList = '';
if($_REQUEST['Comments']) {
foreach($_REQUEST['Comments'] as $commentid) {
$comment = DataObject::get_by_id('Comment', $commentid);
if($comment) {
$comment->IsSpam = false;
$comment->Moderated = true;
$comment->write();
$numComments++;
}
}
} else {
user_error("No comments in $commentList could be found!", E_USER_ERROR);
}
$msg = sprintf(_t('CommentAdmin.APPROVED', 'Accepted %s comments.'), $numComments);
echo <<<JS
$deleteList
$('Form_EditForm').getPageFromServer($('Form_EditForm_ID').value);
statusMessage("Accepted $numComments comments.");
JS;
}
/**
* Return the number of moderated comments
*
* @return int
*/
function NumModerated() {
return DB::query("SELECT COUNT(*) FROM \"Comment\" WHERE \"Moderated\" = 1")->value();
}
/**
* Return the number of unmoderated comments
*
* @return int
*/
function NumUnmoderated() {
return DB::query("SELECT COUNT(*) FROM \"Comment\" WHERE \"Moderated\" = 0")->value();
}
/**
* Return the number of comments marked as spam
*
* @return int
*/
function NumSpam() {
return DB::query("SELECT COUNT(*) FROM \"Comment\" WHERE \"IsSpam\" = 1")->value();
}
/**
* @param int
*/
function set_comments_per_page($num){
self::$comments_per_page = $num;
}
/**
* @return int
*/
function get_comments_per_page(){
return self::$comments_per_page;
}
} }