Regions
Contents
Usage
Regions are declared statically within other components. Below is a sample definition of a page component with a single region main
:
Example - page component with a single region
<page>
<display-name>The main page</display-name>
<form/>
<regions>
<region name="main"/>
</regions>
</page>
And here is a layout defining three regions:
Sample layout with three regions
<layout>
<display-name>The main page</display-name>
<form/>
<regions>
<region name="left"/>
<region name="middle"/>
<region name="right"/>
</regions>
</layout>
From Content Studio, this is what regions look like in the page form:
data:image/s3,"s3://crabby-images/20ae2/20ae270d181073d7825faea64c24d07ec9dc3ae7" alt="Component editor"
And here is what the the exact same structure might look like in the visual page editor.
Ther dropzones are empty regions. |
data:image/s3,"s3://crabby-images/f9836/f9836f13f1164b2312dad6fbe582230517ec88bf" alt="Layout with three empty regions"
Output
Using the Content API, you may access a JSON version containing the hierarchical structure of components and regions on the page.
Sample JSON from the Content api
"page": {
"type": "page",
"path": "/",
"descriptor": "com.enonic.app.superhero:default",
"regions": {
"main": {
"components": [
{
"path": "/main/0",
"type": "layout",
"descriptor": "com.enonic.app.superhero:three-column",
"config": {},
"regions": {}
}
],
"name": "main"
}
}
}
Empty regions are never persisted. Region names are only determined from the component path. |