1
0
mirror of https://github.com/silverstripe/silverstripe-blog synced 2024-10-22 11:05:58 +02:00

Merge pull request from assertchris/add-tag-field

Added tag field
This commit is contained in:
Damian Mooyman 2015-04-14 14:18:19 +12:00
commit 6130f81753
2 changed files with 98 additions and 29 deletions

View File

@ -168,16 +168,20 @@ class BlogPost extends Page {
$options = BlogAdminSidebar::create( $options = BlogAdminSidebar::create(
$publishDate = DatetimeField::create("PublishDate", _t("BlogPost.PublishDate", "Publish Date")), $publishDate = DatetimeField::create("PublishDate", _t("BlogPost.PublishDate", "Publish Date")),
$urlSegment, $urlSegment,
ListboxField::create( TagField::create(
"Categories", 'Categories',
_t("BlogPost.Categories", "Categories"), _t('BlogPost.Categories', 'Categories'),
$self->Parent()->Categories()->map()->toArray() $self->Parent()->Categories()->map(),
)->setMultiple(true), $self->Categories()->map(),
ListboxField::create( !$this->canCreateCategories()
"Tags", ),
_t("BlogPost.Tags", "Tags"), TagField::create(
$self->Parent()->Tags()->map()->toArray() 'Tags',
)->setMultiple(true), _t('BlogPost.Tags', 'Tags'),
$self->Parent()->Tags()->map(),
$self->Tags()->map(),
!$this->canCreateTags()
),
$authorField, $authorField,
$authorNames $authorNames
)->setTitle('Post Options'); )->setTitle('Post Options');
@ -195,6 +199,48 @@ class BlogPost extends Page {
return $fields; return $fields;
} }
/**
* Determine whether user can create new categories.
*
* @param int|Member|null $member
*
* @return bool
*/
public function canCreateCategories($member = null) {
$member = $member ?: Member::currentUser();
if(is_numeric($member)) $member = Member::get()->byID($member);
$parent = $this->Parent();
if(!$parent || !$parent->exists() || !($parent instanceof Blog)) return false;
if($parent->isEditor($member)) return true;
return Permission::checkMember($member, 'ADMIN');
}
/**
* Determine whether user can create new tags.
*
* @param int|Member|null $member
*
* @return bool
*/
public function canCreateTags($member = null) {
$member = $member ?: Member::currentUser();
if(is_numeric($member)) $member = Member::get()->byID($member);
$parent = $this->Parent();
if(!$parent || !$parent->exists() || !($parent instanceof Blog)) return false;
if($parent->isEditor($member)) return true;
if($parent->isWriter($member)) return true;
return Permission::checkMember($member, 'ADMIN');
}
protected function onBeforeWrite() { protected function onBeforeWrite() {
parent::onBeforeWrite(); parent::onBeforeWrite();
@ -220,7 +266,25 @@ class BlogPost extends Page {
} }
} }
/**
* Sets blog relationship on all categories and tags assigned to this post.
*
* @throws ValidationException
*/
public function onAfterWrite()
{
parent::onAfterWrite();
foreach ($this->Categories() as $category) {
$category->BlogID = $this->ParentID;
$category->write();
}
foreach ($this->Tags() as $tag) {
$tag->BlogID = $this->ParentID;
$tag->write();
}
}
/** /**
* Checks the publish date to see if the blog post has actually been published. * Checks the publish date to see if the blog post has actually been published.

View File

@ -1,11 +1,16 @@
{ {
"name": "silverstripe/blog", "name": "silverstripe/blog",
"description": "A fresh take on blogging in Silverstripe set out to tackle the issue of a cluttered Site Tree.", "description": "A fresh take on blogging in Silverstripe set out to tackle the issue of a cluttered Site Tree.",
"keywords": ["silverstripe", "blog", "news"], "keywords": [
"silverstripe",
"blog",
"news"
],
"type": "silverstripe-module", "type": "silverstripe-module",
"require": { "require": {
"silverstripe/cms": ">=3.1.0", "silverstripe/cms": ">=3.1.0",
"silverstripe/lumberjack": "~1.1" "silverstripe/lumberjack": "~1.1",
"silverstripe/tagfield": "dev-develop"
}, },
"require-dev": { "require-dev": {
"phpunit/PHPUnit": "~3.7@stable" "phpunit/PHPUnit": "~3.7@stable"