iqnection-pages / pagebuilder
SilverStripe Page Builder Page
Installs: 30
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
Type:silverstripe-vendormodule
Requires
This package is auto-updated.
Last update: 2024-11-07 03:21:25 UTC
README
Provides an interface to build out a custom content page. Includes Content Builder Section [CMS Previews are still in development]
Installation
composer require iqnection-pages/pagebuilder
Content Builder Section
This section allows you to stack modules for unique content layouts. Each block is a row within the section Includes blocks for:
- Headline
- Full width content
- Two column content
- Three collumn content
- Horizontal bar
- RSS Blog feed (developed for WordPress feed)
Custom Content Builder Blocks
Extend IQnection\PageBuilder\ContentBuilder\Block\Block to build your own
Config
Section Background Colors
Sections can be set to have background colors or images. To set background colors, you must first declare the class in your stylesheets
.bg-black { background:#000000; }
.bg-white { background:#FFFFFF; }
Then add a config value for each class declared Each value should be a key value, where the key is the dropdown option label, and the value should be the class that will be assigned to the block
IQnection\PageBuilder\Section\PageBuilderSection:
background_colors:
'Black': 'bg-black'
'White': 'bg-white'
You can also assign borders to the top and bottom This CSS is generated for you, so all you need to do is provide the colors to select from
#IQnection\PageBuilder\Section\PageBuilderSection:
border_colors:
'Black': '#000000'
'White': '#ffffff'
Headline Block
Set key value pairs for the color and class to assign the font color Declare a class in your stylesheet that sets the font color
.text-black,
.text-black * { color:#000000 !important; }
Then add the value to your config to make it a selection
IQnection\PageBuilder\ContentBuilder\Block\Headline:
colors:
'Black': 'text-black'
'White': 'text-white'
Horizontal Bar
This block is helpful when you want to divide content but maintain a background image through what appears to be multiple sections Add the options to your config to make it a selection, the styles should already be declared from setting up the PageBuilderSection background colors above
IQnection\PageBuilder\ContentBuilder\Block\HorizontalBar:
colors:
'Black': 'bg-black'
'White': 'bg-white'
Blog Feed Block
Set the cache lifetime for the feed
Use the format expected for php strtotime()
defaults to 1 hour
IQnection\PageBuilder\ContentBuilder\Block\BlogFeed:
feed_cache_lifetime: '-1 hour'
Custom Modules
Custom modules can be created by extending class IQnection\PageBuilder\Section\PageBuilderSection Sections might include forms, or predefined layouts, whatever you can build
Hooks
IQnection\PageBuilder\PageBuilder:
- updateCustomCSS: add or edit the custom CSS thats generated from all sections
IQnection\PageBuilder\Section:
- updateCSSClasses: add or change CSS classes that are set on the section element
- updateCustomCSS: add or edit the custom CSS thats generated for the section element
IQnection\PageBuilder\ContentBuilder\Block\Block:
- updateSectionCSSClasses: add or change CSS classes that are assigned to the block element container
- updateCSSClasses: add or change CSS classes that are assigned to the block element
- updateCustomCSS: add or edit the custom CSS thats generated for the block element
Import/Export
Still in development