2010-11-30 01:33:19 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Extension to {@link DataObject} to enable tracking comments.
|
|
|
|
*
|
|
|
|
* @package comments
|
|
|
|
*/
|
|
|
|
|
|
|
|
class CommentsExtension extends DataObjectDecorator {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a relationship between this {@link DataObject} and its
|
2010-11-30 04:30:10 +01:00
|
|
|
* {@link Comment} objects. If the owner class is a sitetree class
|
|
|
|
* it also enables a checkbox allowing comments to be turned off and off
|
2010-11-30 01:33:19 +01:00
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function extraStatics() {
|
2010-11-30 04:30:10 +01:00
|
|
|
$fields = array();
|
|
|
|
|
|
|
|
$relationships = array(
|
2010-11-30 01:33:19 +01:00
|
|
|
'has_many' => array(
|
|
|
|
'Comments' => 'Comment'
|
|
|
|
)
|
|
|
|
);
|
2010-11-30 04:30:10 +01:00
|
|
|
|
|
|
|
// if it is attached to the SiteTree then we need to add ProvideComments
|
|
|
|
// cannot check $this->owner as this in intialised via call_user_func
|
|
|
|
$args = func_get_args();
|
|
|
|
|
|
|
|
if($args && ($owner = array_shift($args))) {
|
|
|
|
if(ClassInfo::is_subclass_of($owner, 'SiteTree') || $owner == "SiteTree") {
|
|
|
|
$fields = array(
|
|
|
|
'db' => array(
|
|
|
|
'ProvideComments' => 'Boolean'
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return array_merge($fields, $relationships);
|
2010-11-30 01:33:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var int Number of comments to show per page
|
|
|
|
*/
|
|
|
|
private static $comments_per_page = 10;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the number of comments displayed per page
|
|
|
|
*
|
|
|
|
* @param int Number of comments to show per page
|
|
|
|
*/
|
|
|
|
public static function set_comments_per_page($num) {
|
|
|
|
self::$comments_per_page = (int)$num;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the number of comments per page
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public static function comments_per_page() {
|
|
|
|
return self::$comments_per_page;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of all the comments attached to this record.
|
|
|
|
*
|
|
|
|
* @todo pagination
|
|
|
|
*
|
|
|
|
* @return DataObjectSet
|
|
|
|
*/
|
|
|
|
function Comments() {
|
|
|
|
return DataObject::get('Comment', "\"ParentID\" = '". $this->owner->ID ."' AND \"ParentClass\" = '". $this->ownerBaseClass ."'");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Comments interface for the front end. Includes the CommentAddForm and the composition
|
|
|
|
* of the comments display.
|
|
|
|
*
|
|
|
|
* To customize the html see templates/CommentInterface.ss or extend this function with
|
|
|
|
* your own extension.
|
|
|
|
*
|
|
|
|
* @see docs/en/Extending
|
|
|
|
*/
|
2010-11-30 04:30:10 +01:00
|
|
|
public function CommentsForm() {
|
2010-11-30 01:33:19 +01:00
|
|
|
$interface = new SSViewer('CommentsInterface');
|
|
|
|
|
|
|
|
return $interface->process(new ArrayData(array(
|
2010-11-30 04:30:10 +01:00
|
|
|
'AddCommentForm' => $this->AddCommentForm(),
|
2010-11-30 01:33:19 +01:00
|
|
|
'Comments' => $this->Comments()
|
|
|
|
)));
|
|
|
|
}
|
|
|
|
|
2010-11-30 04:30:10 +01:00
|
|
|
/**
|
|
|
|
* Add Comment Form.
|
|
|
|
*
|
|
|
|
* @see CommentForm
|
|
|
|
* @return Form|bool
|
|
|
|
*/
|
|
|
|
public function AddCommentForm() {
|
|
|
|
|
|
|
|
// detect whether we comments are enabled. By default if $CommentsForm is included
|
|
|
|
// on a {@link DataObject} then it is enabled, however {@link SiteTree} objects can
|
|
|
|
// trigger comments on / off via ProvideComments
|
|
|
|
if($this->attachedToSiteTree() && !$this->owner->ProvideComments) return false;
|
|
|
|
|
|
|
|
$form = new CommentForm(Controller::curr(), 'CommentsForm');
|
|
|
|
|
|
|
|
// hook to allow further extensions to alter the comments form
|
|
|
|
$this->extend('alterAddCommentForm', $form);
|
|
|
|
|
|
|
|
return $form;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns whether this extension instance is attached to a {@link SiteTree} object
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function attachedToSiteTree() {
|
|
|
|
return ClassInfo::is_subclass_of($this->ownerBaseClass, 'SiteTree');
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2010-11-30 01:33:19 +01:00
|
|
|
/**
|
|
|
|
* @deprecated 1.0 Please use {@link CommentsExtension->CommentsForm()}
|
|
|
|
*/
|
|
|
|
function PageComments() {
|
2010-11-30 04:30:10 +01:00
|
|
|
user_error('$PageComments is deprecated. Please use $CommentsForm', E_USER_WARNING);
|
2010-11-30 01:33:19 +01:00
|
|
|
|
|
|
|
return $this->CommentsForm();
|
|
|
|
}
|
|
|
|
}
|