mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 06:05:56 +00:00
383358fa05
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/branches/2.4@105277 467b73ca-7a2a-4603-9d3b-597d59a354a9
109 lines
3.1 KiB
PHP
109 lines
3.1 KiB
PHP
<?php
|
|
/**
|
|
* Special kind of ComplexTableField for managing comments.
|
|
* @package cms
|
|
* @subpackage comments
|
|
*/
|
|
class CommentTableField extends ComplexTableField {
|
|
protected $template = "CommentTableField";
|
|
protected $mode;
|
|
|
|
function __construct($controller, $name, $sourceClass, $mode, $fieldList, $detailFormFields = null, $sourceFilter = "", $sourceSort = "Created", $sourceJoin = "") {
|
|
$this->mode = $mode;
|
|
|
|
Session::set('CommentsSection', $mode);
|
|
|
|
parent::__construct($controller, $name, $sourceClass, $fieldList, $detailFormFields, $sourceFilter, $sourceSort, $sourceJoin);
|
|
|
|
$this->Markable = true;
|
|
|
|
// Note: These keys have special behaviour associated through TableListField.js
|
|
$this->selectOptions = array(
|
|
'all' => _t('CommentTableField.SELECTALL', 'All'),
|
|
'none' => _t('CommentTableField.SELECTNONE', 'None')
|
|
);
|
|
|
|
// search
|
|
$search = isset($_REQUEST['CommentSearch']) ? Convert::raw2sql($_REQUEST['CommentSearch']) : null;
|
|
if(!empty($_REQUEST['CommentSearch'])) {
|
|
$this->sourceFilter[] = "( \"Name\" LIKE '%$search%' OR \"Comment\" LIKE '%$search%')";
|
|
}
|
|
}
|
|
|
|
function FieldHolder() {
|
|
$ret = parent::FieldHolder();
|
|
|
|
Requirements::javascript(CMS_DIR . '/javascript/CommentTableField.js');
|
|
|
|
return $ret;
|
|
}
|
|
|
|
function Items() {
|
|
$this->sourceItems = $this->sourceItems();
|
|
|
|
if(!$this->sourceItems) {
|
|
return null;
|
|
}
|
|
|
|
$pageStart = (isset($_REQUEST['ctf'][$this->Name()]['start']) && is_numeric($_REQUEST['ctf'][$this->Name()]['start'])) ? $_REQUEST['ctf'][$this->Name()]['start'] : 0;
|
|
$this->sourceItems->setPageLimits($pageStart, $this->pageSize, $this->totalCount);
|
|
|
|
$output = new DataObjectSet();
|
|
foreach($this->sourceItems as $pageIndex=>$item) {
|
|
$output->push(Object::create('CommentTableField_Item',$item, $this, $pageStart+$pageIndex));
|
|
}
|
|
return $output;
|
|
}
|
|
|
|
function HasSpamButton() {
|
|
return $this->mode == 'approved' || $this->mode == 'unmoderated';
|
|
}
|
|
|
|
function HasApproveButton() {
|
|
return $this->mode == 'unmoderated';
|
|
}
|
|
|
|
function HasHamButton() {
|
|
return $this->mode == 'spam';
|
|
}
|
|
|
|
function SearchForm() {
|
|
$query = isset($_GET['CommentSearch']) ? $_GET['CommentSearch'] : null;
|
|
|
|
$searchFields = new FieldGroup(
|
|
new TextField('CommentSearch', _t('CommentTableField.SEARCH', 'Search'), $query),
|
|
new HiddenField("ctf[ID]",'',$this->mode),
|
|
new HiddenField('CommentFieldName','',$this->name)
|
|
);
|
|
|
|
$actionFields = new LiteralField('CommentFilterButton','<input type="submit" name="CommentFilterButton" value="'. _t('CommentTableField.FILTER', 'Filter') .'" id="CommentFilterButton"/>');
|
|
|
|
$fieldContainer = new FieldGroup(
|
|
$searchFields,
|
|
$actionFields
|
|
);
|
|
|
|
return $fieldContainer->FieldHolder();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Single row of a {@link CommentTableField}
|
|
* @package cms
|
|
* @subpackage comments
|
|
*/
|
|
class CommentTableField_Item extends ComplexTableField_Item {
|
|
function HasSpamButton() {
|
|
return $this->parent()->HasSpamButton();
|
|
}
|
|
|
|
function HasApproveButton() {
|
|
return $this->parent()->HasApproveButton();
|
|
}
|
|
|
|
function HasHamButton() {
|
|
return $this->parent()->HasHamButton();
|
|
}
|
|
}
|
|
|
|
?>
|