2012-05-21 14:58:26 +12:00
< ? php
/**
* @ package blog
*/
/**
* Blog holder to display summarised blog entries .
*
* A blog holder is the leaf end of a BlogTree , but can also be used standalone in simpler circumstances .
* BlogHolders can only hold BlogEntries , BlogTrees can only hold BlogTrees and BlogHolders
* BlogHolders have a form on them for easy posting , and an owner that can post to them , BlogTrees don ' t
*/
class BlogHolder extends BlogTree implements PermissionProvider {
2013-04-04 15:30:33 +13:00
private static $icon = " blog/images/blogholder-file.png " ;
2013-04-11 01:01:09 +02:00
2013-04-04 15:30:33 +13:00
private static $description = " Displays listings of blog entries " ;
2012-10-09 10:14:31 +10:00
2013-04-04 15:30:33 +13:00
private static $singular_name = 'Blog Holder Page' ;
2013-04-11 01:01:09 +02:00
2013-04-04 15:30:33 +13:00
private static $plural_name = 'Blog Holder Pages' ;
2012-09-21 11:39:31 -04:00
2013-04-04 15:30:33 +13:00
private static $db = array (
2012-05-21 14:58:26 +12:00
'AllowCustomAuthors' => 'Boolean' ,
2012-10-18 10:10:16 +13:00
'ShowFullEntry' => 'Boolean' ,
2012-05-21 14:58:26 +12:00
);
2013-04-04 15:30:33 +13:00
private static $has_one = array (
2012-05-21 14:58:26 +12:00
'Owner' => 'Member' ,
);
2013-04-04 15:30:33 +13:00
private static $allowed_children = array (
2012-05-21 14:58:26 +12:00
'BlogEntry'
);
function getCMSFields () {
$blogOwners = $this -> blogOwners ();
SiteTree :: disableCMSFieldsExtensions ();
$fields = parent :: getCMSFields ();
SiteTree :: enableCMSFieldsExtensions ();
2012-11-13 09:59:48 +13:00
2013-04-11 01:01:09 +02:00
$fields -> addFieldToTab (
'Root.Main' ,
DropdownField :: create ( 'OwnerID' , 'Blog owner' , $blogOwners -> map ( 'ID' , 'Name' ) -> toArray ())
-> setEmptyString ( '(None)' )
-> setHasEmptyDefault ( true ),
" Content "
);
2012-08-17 14:08:43 +12:00
$fields -> addFieldToTab ( 'Root.Main' , new CheckboxField ( 'AllowCustomAuthors' , 'Allow non-admins to have a custom author field' ), " Content " );
2013-04-11 01:01:32 +02:00
$fields -> addFieldToTab (
" Root.Main " ,
CheckboxField :: create ( " ShowFullEntry " , " Show Full Entry " )
-> setDescription ( 'Show full content in overviews rather than summary' ),
" Content "
);
2012-05-21 14:58:26 +12:00
$this -> extend ( 'updateCMSFields' , $fields );
return $fields ;
}
/**
* Get members who have BLOGMANAGEMENT and ADMIN permission
*/
2012-05-21 15:58:40 +12:00
2012-05-21 14:58:26 +12:00
function blogOwners ( $sort = array ( 'FirstName' => 'ASC' , 'Surname' => 'ASC' ), $direction = null ) {
$members = Permission :: get_members_by_permission ( array ( 'ADMIN' , 'BLOGMANAGEMENT' ));
$members -> sort ( $sort );
$this -> extend ( 'extendBlogOwners' , $members );
return $members ;
}
public function BlogHolderIDs () {
return array ( $this -> ID );
}
/*
* @ todo : These next few functions don ' t really belong in the model . Can we remove them ?
*/
/**
* Only display the blog entries that have the specified tag
*/
function ShowTag () {
if ( $this -> request -> latestParam ( 'Action' ) == 'tag' ) {
return Convert :: raw2xml ( Director :: urlParam ( 'ID' ));
}
}
/**
* Check if url has " /post "
*/
function isPost () {
return $this -> request -> latestParam ( 'Action' ) == 'post' ;
}
/**
* Link for creating a new blog entry
*/
function postURL (){
return $this -> Link ( 'post' );
}
/**
* Returns true if the current user is an admin , or is the owner of this blog
*
* @ return Boolean
*/
function IsOwner () {
return ( Permission :: check ( 'BLOGMANAGEMENT' ) || Permission :: check ( 'ADMIN' ));
}
/**
* Create default blog setup
*/
function requireDefaultRecords () {
parent :: requireDefaultRecords ();
2014-02-27 15:52:27 +13:00
// Skip creation of default records
if ( ! self :: config () -> create_default_pages ) return ;
2012-05-21 14:58:26 +12:00
$blogHolder = DataObject :: get_one ( 'BlogHolder' );
//TODO: This does not check for whether this blogholder is an orphan or not
if ( ! $blogHolder ) {
$blogholder = new BlogHolder ();
$blogholder -> Title = " Blog " ;
$blogholder -> URLSegment = " blog " ;
$blogholder -> Status = " Published " ;
2013-04-16 15:28:45 +02:00
$blogholder -> write ();
$blogholder -> publish ( " Stage " , " Live " );
2012-05-21 14:58:26 +12:00
2013-04-16 15:28:45 +02:00
// Add default widgets to first found WidgetArea relationship
2012-05-28 18:12:53 +12:00
if ( class_exists ( 'WidgetArea' )) {
2013-04-16 15:28:45 +02:00
foreach ( $this -> has_one () as $name => $class ) {
2013-10-21 10:19:41 +02:00
if ( $class == 'WidgetArea' || is_subclass_of ( $class , 'WidgetArea' )) {
2013-04-16 15:28:45 +02:00
$relationName = " { $name } ID " ;
$widgetarea = new WidgetArea ();
$widgetarea -> write ();
2012-05-28 18:12:53 +12:00
2013-04-16 15:28:45 +02:00
$blogholder -> $relationName = $widgetarea -> ID ;
$blogholder -> write ();
$blogholder -> publish ( " Stage " , " Live " );
2012-05-28 18:12:53 +12:00
2013-04-16 15:28:45 +02:00
$managementwidget = new BlogManagementWidget ();
$managementwidget -> ParentID = $widgetarea -> ID ;
$managementwidget -> write ();
2012-05-28 18:12:53 +12:00
2013-04-16 15:28:45 +02:00
$tagcloudwidget = new TagCloudWidget ();
$tagcloudwidget -> ParentID = $widgetarea -> ID ;
$tagcloudwidget -> write ();
2012-05-28 18:12:53 +12:00
2013-04-16 15:28:45 +02:00
$archivewidget = new ArchiveWidget ();
$archivewidget -> ParentID = $widgetarea -> ID ;
$archivewidget -> write ();
2012-05-28 18:12:53 +12:00
2013-04-16 15:28:45 +02:00
$widgetarea -> write ();
2012-05-28 18:12:53 +12:00
2013-04-16 15:28:45 +02:00
break ; // only apply to one
}
}
}
2012-05-21 14:58:26 +12:00
$blog = new BlogEntry ();
$blog -> Title = _t ( 'BlogHolder.SUCTITLE' , " SilverStripe blog module successfully installed " );
$blog -> URLSegment = 'sample-blog-entry' ;
$blog -> Tags = _t ( 'BlogHolder.SUCTAGS' , " silverstripe, blog " );
2013-04-16 15:28:45 +02:00
$blog -> Content = _t ( 'BlogHolder.SUCCONTENT' , " <p>Congratulations, the SilverStripe blog module has been successfully installed. This blog entry can be safely deleted. You can configure aspects of your blog in <a href= \" admin \" >the CMS</a>.</p> " );
2012-05-21 14:58:26 +12:00
$blog -> Status = " Published " ;
$blog -> ParentID = $blogholder -> ID ;
$blog -> write ();
$blog -> publish ( " Stage " , " Live " );
DB :: alteration_message ( " Blog page created " , " created " );
}
}
2013-04-14 23:18:00 +02:00
function providePermissions () {
return array ( " BLOGMANAGEMENT " => " Blog management " );
}
2012-05-21 14:58:26 +12:00
}
class BlogHolder_Controller extends BlogTree_Controller {
2013-04-04 15:24:53 +13:00
private static $allowed_actions = array (
2012-05-21 14:58:26 +12:00
'index' ,
'tag' ,
'date' ,
'metaweblog' ,
'postblog' => 'BLOGMANAGEMENT' ,
2013-03-18 11:00:04 +13:00
'post' ,
2012-05-21 14:58:26 +12:00
'BlogEntryForm' => 'BLOGMANAGEMENT' ,
);
function init () {
parent :: init ();
Requirements :: themedCSS ( " bbcodehelp " );
}
/**
* Return list of usable tags for help
*/
function BBTags () {
return BBCodeParser :: usable_tags ();
}
/**
* Post a new blog entry
*/
function post (){
if ( ! Permission :: check ( 'BLOGMANAGEMENT' )) return Security :: permissionFailure ();
$page = $this -> customise ( array (
'Content' => false ,
'Form' => $this -> BlogEntryForm ()
));
return $page -> renderWith ( 'Page' );
}
/**
* A simple form for creating blog entries
*/
function BlogEntryForm () {
if ( ! Permission :: check ( 'BLOGMANAGEMENT' )) return Security :: permissionFailure ();
$id = 0 ;
if ( $this -> request -> latestParam ( 'ID' )) {
$id = ( int ) $this -> request -> latestParam ( 'ID' );
}
$codeparser = new BBCodeParser ();
$membername = Member :: currentUser () ? Member :: currentUser () -> getName () : " " ;
if ( BlogEntry :: $allow_wysiwyg_editing ) {
$contentfield = new HtmlEditorField ( " BlogPost " , _t ( " BlogEntry.CN " ));
} else {
$contentfield = new CompositeField (
new LiteralField ( " BBCodeHelper " , " <a id= \" BBCodeHint \" target='new'> " . _t ( " BlogEntry.BBH " ) . " </a><div class='clear'><!-- --></div> " ),
new TextareaField ( " BlogPost " , _t ( " BlogEntry.CN " ), 20 ), // This is called BlogPost as the id #Content is generally used already
new LiteralField ( " BBCodeTags " , " <div id= \" BBTagsHolder \" > " . $codeparser -> useable_tagsHTML () . " </div> " )
);
}
if ( class_exists ( 'TagField' )) {
$tagfield = new TagField ( 'Tags' , null , null , 'BlogEntry' );
$tagfield -> setSeparator ( ', ' );
} else {
$tagfield = new TextField ( 'Tags' );
}
$field = 'TextField' ;
if ( ! $this -> AllowCustomAuthors && ! Permission :: check ( 'ADMIN' )) {
$field = 'ReadonlyField' ;
}
$fields = new FieldList (
new HiddenField ( " ID " , " ID " ),
new TextField ( " Title " , _t ( 'BlogHolder.SJ' , " Subject " )),
new $field ( " Author " , _t ( 'BlogEntry.AU' ), $membername ),
$contentfield ,
$tagfield ,
new LiteralField ( " Tagsnote " , " <label id='tagsnote'> " . _t ( 'BlogHolder.TE' , " For example: sport, personal, science fiction " ) . " <br/> " .
_t ( 'BlogHolder.SPUC' , " Please separate tags using commas. " ) . " </label> " )
);
$submitAction = new FormAction ( 'postblog' , _t ( 'BlogHolder.POST' , 'Post blog entry' ));
2012-05-21 15:58:40 +12:00
2012-05-21 14:58:26 +12:00
$actions = new FieldList ( $submitAction );
$validator = new RequiredFields ( 'Title' , 'BlogPost' );
$form = new Form ( $this , 'BlogEntryForm' , $fields , $actions , $validator );
if ( $id != 0 ) {
$entry = DataObject :: get_by_id ( 'BlogEntry' , $id );
if ( $entry -> IsOwner ()) {
$form -> loadDataFrom ( $entry );
$form -> Fields () -> fieldByName ( 'BlogPost' ) -> setValue ( $entry -> Content );
2012-05-21 15:58:40 +12:00
2012-05-21 14:58:26 +12:00
}
} else {
$form -> loadDataFrom ( array ( " Author " => Cookie :: get ( " BlogHolder_Name " )));
}
return $form ;
}
function postblog ( $data , $form ) {
if ( ! Permission :: check ( 'BLOGMANAGEMENT' )) return Security :: permissionFailure ();
Cookie :: set ( " BlogHolder_Name " , $data [ 'Author' ]);
$blogentry = false ;
if ( isset ( $data [ 'ID' ]) && $data [ 'ID' ]) {
$blogentry = DataObject :: get_by_id ( " BlogEntry " , $data [ 'ID' ]);
if ( ! $blogentry -> IsOwner ()) {
unset ( $blogentry );
}
}
if ( ! $blogentry ) {
$blogentry = new BlogEntry ();
}
$form -> saveInto ( $blogentry );
$blogentry -> ParentID = $this -> ID ;
$blogentry -> Content = str_replace ( " \r \n " , " \n " , $form -> Fields () -> fieldByName ( 'BlogPost' ) -> dataValue ());
if ( Object :: has_extension ( $this -> ClassName , 'Translatable' )) {
$blogentry -> Locale = $this -> Locale ;
}
2014-08-25 11:06:01 +12:00
$oldMode = Versioned :: get_reading_mode ();
Versioned :: reading_stage ( 'Stage' );
$blogentry -> write ();
2012-05-21 14:58:26 +12:00
$blogentry -> publish ( " Stage " , " Live " );
2014-08-25 11:06:01 +12:00
Versioned :: set_reading_mode ( $oldMode );
2012-05-21 14:58:26 +12:00
2012-06-21 13:45:07 +12:00
$this -> redirect ( $this -> Link ());
2012-05-21 14:58:26 +12:00
}
}