Skip to content

Commit

Permalink
Merge branch 'release/0.3.0'
Browse files Browse the repository at this point in the history
  • Loading branch information
Severin Hauser committed Apr 19, 2023
2 parents 10283d2 + 5e1fb75 commit 27c1d31
Show file tree
Hide file tree
Showing 37 changed files with 3,377 additions and 1,647 deletions.
4 changes: 4 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
vendor/
composer.lock
resources/
.vscode
Empty file modified LICENSE
100644 → 100755
Empty file.
213 changes: 60 additions & 153 deletions README.md
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,168 +1,75 @@
# Page Sections module

**Adds configurable page sections and elements to your SilverStripe project.**
# Silverstripe Pagesections

**Elemental alternative for configurable page sections and elements.**

## Introduction

This module provides page sections for SilverStripe 3.+ projects.
Page sections are areas on a page where CMS users can add their own content
in a structured way.
Pages can have none, one or more page sections attached to them. Each page section
is made up of various page elements, which themselves can or cannot have other
page elements as children. The page elements can be edited in a tree-like gridview
on the page or the page elements.

This module provides page sections for SilverStripe 4.x projects. Page sections are areas on a page where CMS users can add their own content in a structured way. Pages can have none, one or more page sections attached to them. Each page section is made up of various page elements, which themselves can or cannot have other page elements as children.

## Setup
## Installation

You can either add this module to your composer file using
```
```sh
composer require flxlabs/silverstripe-pagesections
```
or download the git repository and add a folder called `pagesections` to the top level
of your project and drop the code in there.

> By default the module is configured to do nothing, and also doesn't add any relations.
Please refer to the **Configure** section for more information.


## Configure
Add the extension to the DataObject that should contain a PageSection:

> By default this module does **NOT** add any relations or data to any of your pages.
Follow the steps below to start working with page sections.

### Pages & Page sections
```yml
Page:
extensions:
- PageSectionsExtension

```

Your pages can have none (default), one or more page sections, which are areas on
your page where CMS users can add various page elements to customize the look and feel
of the page in a structered/limited way.
By default the DataObject will have a PageSection called `Main`. To add additional sections, or change the name of the default section, specify them in the `page_sections` key.

1. Add the following extensions to your `mysite/_config/config.yaml` on any pages
where you wish to have page sections:
```
Page:
extensions:
- PageSectionsExtension
- VersionedRelationsExtension
```
This will by default add **one** page section called `Main` to your page(s)
> **Make sure that the *VersionedRelationsExtension* comes after the *PageSectionsExtension***
```yml
Page:
extensions:
- PageSectionsExtension
page_sections:
- Main
- Aside
```
1. If you want more than one page section add the following to your `mysite/_config/config.yaml`:
```
Page:
extensions:
- PageSectionsExtension
- VersionedRelationsExtension
page_sections:
- Top
- Middle
- Bottom
```
Each of the listed names under the `page_sections` key will add a page section of that name to
the page. This will also override the default `Main` page section.

1. Hit up `/dev/build?flush=1` in your browser to rebuild the database. You should see that new
relations are created for each of your page classes that you added page sections to.


### Page elements

Page elements are the actual elements that are added to the page sections and then displayed
on the page. By default this package only contains the base class `PageElement` and not any
actually implemented page elements, but you can take a look at the `examples` folder to see
how some common page elements would look.

Page elements by default have `Children`, which are other page elements, and a `Title`, which
is a `Varchar(255)`.


#### PHP

Below we will demonstrate how to create a simple page element.

1. Create a new file in your `mysite/code` folder called `TextElement.php`

1. Add the following code to that file:
```php
<?php
class TextElement extends PageElement {
public static $singular_name = 'Text';
public static $plural_name = 'Texts';

private static $db = array(
'Content' => 'HTMLText',
);

public function getCMSFields() {
$fields = parent::getCMSFields();
$fields->removeByName('Children');

return $fields;
}

public static function getAllowedPageElements() {
return array();
}

public function getGridFieldPreview() {
return $this->Content;
}
}
```

1. Go to `/dev/build?flush=1` in your browser to load the new class and create database entries.

The class we just created adds the `TextElement` page element, which has a `Content` field that
allows adding html content, and it also removes the `Children` field from it's own CMS fields,
which means that we cannot add any children to this element. This is also enforced in the
`getAllowedPageElements()` function, which returns a list of all the class names of allowed
child elements.

The `getGridFieldPreview()` function returns the content that should be displayed in the gridfield
when editing the page elements.


#### Template

Since this module comes with a default template for the `PageElement` class the `TextElement`
we just created will already render on your page, but most likely not the way you want it to.

There are several ways to customize the look of page elements, analog to how SilverStripe
page templates work.

You can use the following variables/function in any of your page element template files:

| Variable/Function | Description |
|---|---|
| $ClassName | This is the classname of the current page element. |
| $Page | This is the current page that the page element is being displayed on. |
| $Parents | This is an array of the parents of this page element, traveling up the hierarchy. |
| $Layout | This will render the content of the actual page element type, analog to the `$Layout` variable used in the main `Page.ss` file. |
| $RenderChildren($ParentList) | This will loop through all the children of this page element and render them |

Following is an example building on the `TextElement` which was added above.

1. Add a file called `PageElement.ss` to your `/themes/{name}/templates` folder.
**This is the main template file for all your page sections.**

As an example let's use the following content:
```
<div className="$ClassName $Page.ClassName" style="margin-left: {$Parents.Count}em">
<h1>$Title</h1>
$Layout
<div>
$RenderChildren($ParentList)
</div>
</div>
```
Make sure to run `dev/build` and flush.

## Usage

Defining an element:

```php
<?php
class TextElement extends FLXLabs\PageSections\PageElement
{
public static $singular_name = 'Text';
public static $plural_name = 'Texts';
private static $db = [
'Content' => 'HTMLText',
];
// Page elements can have other page elements as children.
// Use this method to restrict allowed childre.
public function getAllowedPageElements()
{
return [
// YourElement::class
];
}
// This will be used to preview the content in the CMS editor
public function getGridFieldPreview()
{
return $this->dbObject('Content')->Summary();
}
}
```

1. Add a file called `TextElement.ss` to your `/themes/{name}/templates/Layout` folder.
Now let's add the following content to that file:
```
$Content
```
To render an element, create a Template. To render a page section use the `RenderPageElements` method exposed by the PageSectionsExtension:

Following the above two steps will add a template for all page elements, as well as a specific
layout template for the `TextElement` page element.
```html
<div>
$RenderPageSection('SectionName')
</div>
```
23 changes: 12 additions & 11 deletions _config/config.yml
100644 → 100755
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
---
Name: pagesections
After:
- 'framework/*'
- 'cms/*'
---
# YAML configuration for SilverStripe
# See http://doc.silverstripe.org/framework/en/topics/configuration
# Caution: Indentation through two spaces, not tabs

PageElement:
extensions:
- Versioned
- VersionedRelationsExtension
FLXLabs\PageSections\PageElement:
extensions:
- SilverStripe\Versioned\Versioned
FLXLabs\PageSections\PageSection:
extensions:
- SilverStripe\Versioned\Versioned
FLXLabs\PageSections\PageElementSelfRel:
extensions:
- SilverStripe\Versioned\Versioned
FLXLabs\PageSections\PageSectionPageElementRel:
extensions:
- SilverStripe\Versioned\Versioned
Loading

0 comments on commit 27c1d31

Please sign in to comment.