Recent Blog Posts Element for the SilverStripe Elemental module.
- silverstripe/blog: ^4.0
- dnadesign/silverstripe-elemental: ^5.0
composer require dynamic/silverstripe-elemental-blog
See License
There are four blocks available for you to use. It is likely that you will not want all of them to be available to
content authors, so it is recommended that you review what the purpose of each block is, and then add the ones you don't
need to disallowed_elements
.
The four blocks are:
A block to show a list of recent posts by a featured blog. Ideal for home pages or dashboards.
The purpose of this block is to replicate the output that was originally being given by the Blog module's Layout
template.
Including:
- Title (including Category/Archive/etc titles)
- Content
- Blog Posts
- Pagination
- Widgets (if the addon as been added and enabled)
You will likely want to override the very basic default template that has been provided, you can do so by overriding the
template found with the namespace Dynamic\Elements\Blog\Elements\ElementBlogOverview.ss
.
Pagination config:
pagination_field_default
:1
(pagination is enabled by default)show_pagination_field
:true
(content authors have the ability to turn pagination on or off)
With the default configuration, when an author creates a new Overview block, they will be presented with a checkbox
to "Show pagination" (which will be ticked by default). If you do not want your authors to be able to disable
pagination, then you can update the show_pagination_field
config to false
.
Dynamic\Elements\Blog\Elements\ElementBlogOverview:
show_pagination_field: false
If you would like pagination to be turned off by default, then you can update the pagination_field_default
to 0
.
Dynamic\Elements\Blog\Elements\ElementBlogOverview:
pagination_field_default: 0
Widget config:
widgets_field_default
:0
(widgets are disabled by default)show_widgets_field
:false
(the "Show widgets" field is not displayed to authors by default)
Because the Widget module is an optional addon, the default settings for Widgets is for them to be disabled. You have the same control over the Widgets config as you do for Pagination.
Please consider: While the Overview block does support you using it on other page types, it is primarily designed to
be used on Blog page types. This is because it is Blog
and BlogController
that provide the relevant info to this
block.
Please consider whether you want this block to be available to other page types, and if you don't, you might want to
add this block to disallowed_elements
on your other page types. EG:
App\Model\Page\MyPage:
disallowed_elements:
- Dynamic\Elements\Blog\Elements\ElementBlogOverview
If you do wish this block to be available on other page types, then please review the contents on the class to see how you can dictate what data should be provided to this block.
You might decide that you would like Pagination to be displayed quite separately to the Overview block. This can be
achieved by using ElementBlogPagination
as a separate block.
Please consider: Like the Overview Block, please consider removing this block from any/all Page types that you do not want it available on. EG, if you don't want to use it at all, you can disallow it for all pages by default:
Page:
disallowed_elements:
- Dynamic\Elements\Blog\Elements\ElementBlogPagination
You might decide that you would like Blog Widgets to be displayed quite separately to the Overview. This can be
achieved by using ElementBlogWidgets
as a separate block.
Please consider: Like the Overview Block, please consider removing this block from any/all Page types that you do not want it available on. EG, if you don't want to use it at all, you can disallow it for all pages by default:
Page:
disallowed_elements:
- Dynamic\Elements\Blog\Elements\ElementBlogWidgets
See Elemental modules by Dynamic
See SilverStripe Elemental Configuration
Bugs are tracked in the issues section of this repository. Before submitting an issue please read over existing issues to ensure yours is unique.
If the issue does look like a new bug:
- Create a new issue
- Describe the steps required to reproduce your issue, and the expected outcome. Unit tests, screenshots and screencasts can help here.
- Describe your environment as detailed as possible: SilverStripe version, Browser, PHP version, Operating System, any installed SilverStripe modules.
Please report security issues to the module maintainers directly. Please don't file security issues in the bugtracker.
If you would like to make contributions to the module please ensure you raise a pull request and discuss with the module maintainers.