Page Types
Page Types in Pala provide a powerful way to define content types, consume page content across your site, and control block composition. This guide covers how to create and manage Page Types effectively.
Creating a Page Type
Basic Setup
Select "Pages" from the toolbar
Click the "Page Types" tab
Click "Create Page Type"
Fill in the required information:
Name (e.g., "Blog Post", "Product Page", "Team Member")
Color and Icon (used within Pala's UI)
Defining Page Content
Page Content defines content assigned to pages of this type. They help maintain consistent content structure across pages and can be used for:
Head content: like 'title' and 'meta' tags
Block content: using the 'Page Content' field type
External blocks: using the 'Page' and 'Page List' field types
Creating a Page Content item
From the Page Type editor, click the 'Content' tab in the sidebar
Click 'Edit Page Type' to open the Page Type editor
Click 'Create Field'
### Block Management
Setting Available Blocks
All blocks belong to the entire site, but they can be enabled or disabled on particular page types to control page building composition for content editors. Content editors will only be able to drop blocks onto the page’s ‘drop zone’.
To toggle available blocks on a given Page Type:
In the Page Type view, click "Blocks" in the sidebar
Toggle blocks on/off to set their availability on pages of the given Page Type
Note: If a block is using a 'Page Property' field that corresponds to a different Page Type, it will appear greyed out. This is because it depends on content which is unavailable on the current page type. If you want to use it for the current page type, you should duplicate it and select the current page type as the selection for the relevant 'Page Property' field.
Configuring Static Blocks
Static blocks are permanently positioned and cannot be removed by content editors. They're useful for maintaining consistent page structures, either loosely to define e.g. the header and footer for a page type, or strictly to define the entire page structure.
To set static blocks:
From the Page Type view, drag a block from the sidebar onto the page
Fill out its content to define the default content for pages of the given type
Note: When no blocks are enabled for a Page Type, 'Blocks' will be hidden in the sidebar for content editors. This is useful for defining page types with a completely static layout (e.g. simple blog posts).
Integrating Page Content
Integrating with Page Head
You can template Page Content with pages in the same way you can integrate block fields with blocks. This is most useful for integrating 'Title', 'Description', and 'Image' fields with 'title' and 'meta' tags in the page head.
Accessing Page Content in Blocks
Page Content is available to all blocks within the page using the 'Page Content' field type. Page Content can be modified from the block, and will be indicated with a 'Page Content' label.
From within the content view of the Block editor, create a new field
Select the 'Page Content' field type
Select the field to retrieve
Using Page and Page List Fields
Page and Page List fields allow you to create relationships between pages and display content from other pages within your blocks.
‘Page’ Field Type
Use the Page field type to reference a single page:
Create a new field in your block
Select 'Page' as the field type
Select the Page Type to restrict the selection to
In the content editor, select the target page
Example uses:
Featured article on homepage
Related product
Team member's supervisor
‘Page List’ Field Type
Use the Page List field type to reference multiple pages:
Create a new field in your block
Select 'Page List' as the field type
Select the Page Type to restrict the selection to
In the content editor, select or reorder pages
Example uses:
Blog post list
Team member directory
Product category listings
Related articles section
Note: at the moment, the ‘Page List’ field type doesn’t enable content editors to filter or select pages. As a workaround, you can manually set up filters by creating additional fields and integrating a filter function in the block’s code.
Example: Creating a 'Team Member' Page Type
Let's walk through creating a complete Page Type for team member profiles:
1. Creating the Page Type
First we'll create the Page Type and set its name, icon, and color. Then we'll select it to open up the Page Type view.
2. Setting static blocks
We'll define the page structure by dragging site blocks onto the page. Usually this means at least the site navigation and site footer, but for this page we'll also include a 'Profile' block which every team member should have.
3. Setting available blocks
We'll also give content editors the ability to add two blocks to Team Member pages: ‘Editorial’, to add any rich text below the team member (like a CV) and ‘Contact Card’ to add their email and social links.
4. Defining and integrating Page Content
Finally, we'll define Page Content for team members. To do so, we click 'Edit Page Type' from the sidebar to open up the Page Type editor, from where we will create relevant fields: Name, Job Title, Short Bio, and Headshot.
Integrating with head
Next we'll click 'Edit Page Type' from the sidebar to open up the Page Type editor, from where we'll integrate the name as the page title, and the short bio and headshot as the page description and image, respectively.
Integrating with internal blocks
Now we'll create a new block to use as the page header for Team Member pages. We'll create 'Name', 'Title', 'Image', and 'Biography' fields. For the first three, we'll select 'Page Content' as the type and select their respective property, but since the fourth one contains content that only lives within this block, we'll select a non-dynamic field type.
Integrating with external blocks
Once we’ve built out our initial list of Team Member pages, we’ll create a a 'Team Member List' block that we'll use on the 'Team' page. To pull in the list of team members, we'll use the 'Page List' field type.