Content Structure
Welcome to the Content Structure documentation.
Here you can find technical descriptions of content entities and fields used by YMCA Website Services site builders. The YMCA Website Services core team has established specifications for fields and created naming conventions to help developers maintain and upgrade their sites alongside the YMCA Website Services development timeline.
Key Concepts
- Content Entity: A fundamental unit of content, such as a page, article, or block.
- Field: A specific data element within a content entity, like a title, body, image, or date.
- Content Type: A pre-defined structure for content entities, specifying the available fields and their configuration.
- Module: A collection of code that extends Drupal’s functionality, potentially introducing new content types, fields, or other features. See
Extending and Altering Drupal.
- Small Y: Refers to a specific set of modules within the YMCA Website Services ecosystem designed for smaller YMCA branches, as detailed in the
Small Y module README.
Content Entities
Content entities are the building blocks of your website’s content. Each content type has a defined set of fields. Here are some commonly used content entities in YMCA Website Services:
- Article: Used for news, announcements, and blog posts. Often includes fields for title, body, image, and publication date. (See also:
ws_small_y/modules/small_y_articles/small_y_articles.info.yml
) - Landing Page: Designed for creating visually appealing and informative pages. Offers flexible layouts and various content areas. (See also:
openy_node_landing.info.yml
) - Promotion: Used to highlight special offers, events, or campaigns. Typically includes fields for title, description, image, and link. (See also:
ws_promotion.info.yml
) - Branch/Facility: Represents a physical YMCA location, including address, hours, amenities, and social links. (See also:
ws_small_y/modules/small_y_branch/small_y_branch.info.yml
, y_facility.info.yml
) - Camp: Content type for YMCA Camps, including integration with Layout Builder. (See also:
y_camp/y_camp.info.yml
)
Fields
Fields store specific data within content entities. Here are some common field types used in YMCA Website Services:
- Text: Stores text content, with options for plain text, formatted text, and summaries.
- Image: Uploads and stores images, with options for alt text and display settings.
- Link: Stores URLs and link text.
- Date: Stores dates and times.
- Entity Reference: Establishes a relationship between one entity and one or more other entities. For example, a “Related Articles” field can link an article to other relevant articles.
- Boolean: Stores true/false values (e.g., a “Featured” checkbox).
- List (Options): Allows users to select a value from a predefined list.
Modules and Content Structure
Several modules contribute to the content structure of YMCA Website Services:
- Y Layout Builder (
y_lb
): Provides a base for layout building functionalities. - Small Y (
ws_small_y
): Offers customizations for smaller YMCAs. See
Small Y module README. - Layout Builder Restrictions: Allows administrators to restrict the available blocks and layouts within the Layout Builder.
- Branch Modules (
lb_branch_*_blocks
): Provide specific block types for displaying branch-related information, such as amenities, hours, and social links. - Staff Members (
lb_staff_members_blocks
& ws_small_y_staff
): Modules for displaying staff members.
Configuration Management
Configuration is managed through YAML files, which define the structure, data types, and translatability of content. See the
Configuration API for details.
Additional Resources
1 - Blocks
What are Blocks?
Blocks are boxes of content rendered into a specific area, or region, of a web page. Blocks are placed and configured specifically for each theme, allowing for customization of content display and layout. Think of them as reusable content containers.
What are Content Blocks?
Content blocks are a specific type of block, where you can edit the content directly through the administrative interface. You can define one or more block types and attach fields to each block type, enabling structured content creation for blocks. Content blocks can be placed just like blocks provided by other modules.
What is the Block Description?
The block description is an administrative label for a block, which is displayed in the administrative interface to help identify the block. It is not displayed to site visitors on the live website.
What is the Block Title?
The block title is the heading that is optionally displayed to site visitors when the block is placed in a region. The visibility of the title can be configured within the block’s settings.
Managing Blocks
The Block module allows you to place existing blocks in regions of your installed themes and configure various block settings, such as title visibility, and user roles. The Block Content module allows you to manage custom block types and create/edit their content.
Additional Resources
1.1 - Basic
A simple block with a description. This block type is commonly used for displaying basic content on a website. It offers a single WYSIWYG field for content creation.
Fields
Name | Machine name | Required | Description |
---|
Content | field_block_content | Yes | WYSIWYG field without summary. Allows rich text formatting. |
1.2 - Block Menu
The Block Menu implements a custom block type with links. Blocks are boxes of content rendered into a region of a web page. Content blocks are blocks whose content you can edit, placing them like blocks provided by other modules. The block description is an identification name for a block, shown in the administrative interface but not displayed on the site. The block title is the heading optionally shown to site visitors when the block is placed in a region.
Fields
Name | Machine name | Required | Description |
---|
Menu Links | field_menu_block_links | Yes | The menu links to be displayed in the block. |
Color | field_menu_block_color | Yes | Select the background gradient color for the menu block. |
Text color | field_menu_block_text_color | Yes | Select the text color for the menu block. |
1.3 - Branch Amenities
A block displaying a list of amenities for the current branch.
Fields
Name | Machine name | Required | Description |
---|
Branch amenities | field_branch_am | Yes | Uses a custom formatter to display a list of amenities within a Paragraph block. This field is a boolean to indicate if the amenity is available. Hidden from content managers by default. |
Link | field_sb_link | No | A link to display at the bottom of the block. Allows for adding attributes like target , rel , and class . |
Title | field_sb_title | No | A title to display at the top of the block. |
Icon class | field_icon_class | No | A Font Awesome icon name, e.g., flag , car , or info . This overrides the image icon. See
Font Awesome for available icons. |
Section Title | field_section_title | No | Section heading |
Section Subtitle | field_section_subtitle | No | Section subheading |
Image | field_image | No | Image for the block. Uses the amenities_image image style. |
1.4 - Custom Simple
A simple block with a body, title, icon and link.
Fields
Name | Machine name | Required | Description |
---|
Icon | field_icon | No | Icon for the block. |
Icon class | field_icon_class | No | Provide a “Font Awesome” icon name, e.g. flag , car , info . Overrides image icon. See available icons
here. |
Body | field_sb_body | No | Enter the main body text for the block. Supports basic HTML. |
Link | field_sb_link | No | Add a link to the block. Provide a full URL. |
Title | field_sb_title | No | Title to display at the top of the block. If left blank, no title will be displayed. |
1.5 - Flexible
The Flexible block provides a way to display content from a referenced node.
Fields
Name | Machine name | Required | Description |
---|
Node reference | field_node_ref | Yes | Provide a reference to a Node. The content of the referenced node will be displayed in the block. |
2 - Content Types
Welcome to the YMCA Website Services Content Types documentation.
In terms of YMCA Website Services, content types are “bundles” of a “node” entity within the Drupal Framework. For more low-level documentation, refer to
drupal.org.
YMCA Website Services ships with a set of content types to simplify site usage. While the number of content types isn’t restricted and developers can add more, the goal is to ensure that the shipped list of content types is covered by the YMCA Website Services upgrade path.
Understanding Content Types
- Content Entity: A content entity is an item of content data like text, images, or files. Content entities are grouped into entity types, which are further divided into entity sub-types to allow for variations in how the entities are used and displayed.
- Fields: Data within content entities is stored in individual fields. Each field holds a specific data type (formatted text, plain text, images, etc.) Fields can be single or multiple-valued.
- Reference Field: A reference field stores a relationship between one entity and one or more other entities.
- Formatter: A formatter determines how a field is displayed.
- Widget: A widget determines how a field is edited.
Managing Content Structure
Several core modules are used to manage content structure:
- Node, Comment, Content Block, Custom Menu Links, User, File, Image, Media, Taxonomy, and Contact modules: Provide content entity types.
- Field UI module: Provides a user interface for managing fields and their display on entities.
- Layout Builder module: Provides a user interface for configuring the display of entities.
- Filter, Responsive Image, and Path modules: Provide settings and display options for entities and fields.
2.1 - Activity
The Activity content type is used for adding Activities to the site. Activities are typically associated with Programs and Classes.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal's default | Yes | Title of the activity item. This is the standard Drupal title field. |
Program Subcategory | field_activity_category | Yes | A reference field for selecting the program subcategory to which the activity belongs. This field connects the Activity to a specific subcategory within the broader program structure. |
Content Area | Field group | | A field group to organize the main content of the Activity. |
Description | field_activity_description | No | Textarea for the description/body of the activity. This field uses a WYSIWYG editor (like CKEditor) for rich text formatting, but does not support a summary field. |
URL pattern
This content type uses the following URL pattern:
/programs/[node:field_activity_category:entity:field_category_program:entity:title]/[node:field_activity_category:entity:title]/[node:title]
Explanation:
/programs/
: Indicates that this is part of the Programs section of the site.[node:field_activity_category:entity:field_category_program:entity:title]
: This part of the URL is dynamically generated from the title of the Program to which the activity subcategory is associated.[node:field_activity_category:entity:title]
: This is dynamically generated from the title of the Activity Category.[node:title]
: This part is dynamically generated from the title of the Activity node itself.
2.2 - Alert
The Alert content type is used for displaying timely information in a banner across the site. Unlike most content types, you don’t use Alert to create pages. Instead, Alerts display as a rendered entity, as a section of content on other pages, either just below the header or above the footer.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the alert, which will display as the headline. |
Background color | field_alert_color | Yes | Reference field for choosing a term from the “Color” vocabulary. |
Text color | field_alert_text_color | Yes | Reference field for choosing a term from the “Color” vocabulary. For accessibility, stick to using either black or white. |
Icon color | field_alert_icon_color | No | Reference field for choosing a term from the “Color” vocabulary. Leave empty to hide the icon. |
Placement | field_alert_place | Yes | Select list field (singular) for choosing placement: |
Description | field_alert_description | Yes | Textarea for the main body of the alert with WYSIWYG (What You See Is What You Get) editor, without summary. Sentences should be short and minimally styled in this section. |
Link | field_alert_link | No | Internal or external link. Adds a button with a call to action to the alert on the right. The button color defaults to black. |
Reference | field_alert_belongs | No | Entity reference with autocomplete to any node. Reference to a node (branch, camp, landing page, etc.) where the alert will be displayed. |
URL pattern
Content type uses the following pattern: /alert/[node:title]
.
2.3 - Article
The Article content type is used for creating blog posts, news items, and press releases on the site.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the article item. This field utilizes the core text field type. See
TextItem.php for more information. |
Sub-title | field_article_subtitle | No | Sub-title of the article item. |
Locations | field_article_location | Yes | Reference field to branch and camp nodes. Allows multiple values. |
Category | field_article_category | No | Reference field for choosing terms from the “Blog Category” vocabulary. Allows multiple values. |
Meta Tags | field_meta_tags | No | A meta tags field that allows providing structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. This utilizes the
Metatag module. |
Type | field_article_type | Yes | Select list field with the following options for choosing the article type: |
| | | - News Item (default) |
| | | - Blog Post |
| | | - Press Release |
Image | field_article_image | No | Image field for the article item. Entity reference to a Media bundle. |
Body | body | No | Text area for the main content of the article. This field uses a WYSIWYG editor and does not include a summary field. |
Content | field_content | No | Filter list of available
Layout Builder components. This field enables the arrangement of content using configurable layouts. |
Related Content | field_article_related | No | Reference field for selecting related Article nodes. Allows multiple values. |
URL patterns
The Article content type uses the following URL patterns:
/blog/[node:title]
/news/[node:title]
/press-release/[node:title]
2.4 - Blog
The Blog Post content type is used for adding blog posts to the site.
Fields
Name | Machine name | Required | Description |
---|
Title | Drupal’s default | Yes | Title of the blog item. |
Locations | field_blog_location | Yes | Reference field to branch and camp nodes. Allows multiple values, enabling association with multiple locations. |
Category | field_blog_category | No | Reference field for choosing terms from the “Blog Category” vocabulary. Allows multiple values, categorizing blogs under several topics. |
Meta Tags | field_meta_tags | No | Allows providing structured metadata and Open Graph meta tags for social networking sites like Facebook, Pinterest, and LinkedIn, enhancing SEO and sharing. |
Styles | Field group | | |
Style | field_blog_style | Yes | Select list field with multiple options for choosing a style: |
| | | - Story Card |
| | | - Photo Card |
| | | - News Card (default) |
| | | - Color Card |
Background color | field_blog_color | No | Background color for the teaser, used when the “Color Card” style is selected. |
Text color | field_blog_text_color | No | Text color for the teaser, used when the “Color Card” style is selected. |
Content Area | Field group | | |
Image | field_blog_image | No | Image field for the Blog item. Entity reference to a Media bundle, allowing selection of pre-uploaded images. |
Description | field_blog_description | No | Textarea for the description/body with WYSIWYG editing capabilities and no summary field. |
Content | field_content | No | A Paragraph embed field that allows adding various flexible content modules from a predefined list of paragraph types. |
Sidebar Area | Field group | | |
Related content | field_blog_related | No | Reference field for choosing related Blog nodes. Allows multiple values for cross-linking content. |
Content | field_sidebar_content | No | A Paragraph embed field that allows adding various flexible content modules to the sidebar, from a predefined list of paragraph types. |
URL pattern
This content type uses the following URL pattern:
/blog/[node:title]
2.5 - Branch
The Branch content type is used for adding and managing branch locations on the site. Each branch can have detailed information, including address, contact details, hours of operation, and associated content.
Fields
Name | Machine name | Required | Description |
---|
Title | Drupal’s default | Yes | Title of the branch item. This is the main identifier for the branch. |
Neighborhood | field_location_area | No | A taxonomy reference field using the “Area” vocabulary. This allows you to categorize branches by geographical area or neighborhood. |
Coming Soon | field_location_state | No | A checkbox field to indicate if the branch is still in development or not yet open to the public. |
Temporary URL | field_location_temp_url | No | A link field to provide a temporary page URL (e.g., a blog post or announcement) if the branch is coming soon and doesn’t have a permanent page yet. |
Meta Tags | field_meta_tags | No | A meta tags field allows you to provide structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. This helps with SEO and social sharing. |
Contact | Field group | | |
Address | field_location_address | Yes | An address field that allows you to add detailed location information. This field stores: |
Branch Coordinates | field_location_coordinates | No | Input for providing the latitude and longitude information. |
Phone | field_location_phone | Yes | Input for providing the branch’s phone number. |
Fax | field_location_fax | No | Input for providing the branch’s fax number (if applicable). |
Email | field_location_email | No | Input for providing the branch’s email address. |
Directions | field_location_directions | No | A link field for adding a directions link (e.g., to a Google Maps page or other online mapping service). |
Branch Hours | Field group | | |
Branch Hours | field_branch_hours | Paragraph | A paragraph field to indicate the branch’s hours of operation. This allows for flexible scheduling, including different hours for different days. |
Day of the week | field_branch_hours_day | No | A select list with the following values:- sunday|Sunday
- monday|Monday
- tuesday|Tuesday
- wednesday|Wednesday
- thursday|Thursday
- friday|Friday
- saturday|Saturday
|
Start/End Time | field_branch_hours_time | No | A text field with a description “e.g. 9am - 5pm, closed.” This field stores the opening and closing times for a specific day. |
Header Area | Field group | | |
Content | field_header_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This allows you to customize the header area of the branch page. |
Content Area | Field group | | |
Content | field_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This is the main content area of the branch page. |
Bottom Area | Field group | | |
Content | field_bottom_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This allows you to add content to the bottom area of the branch page. |
URL pattern
The Branch content type uses the following URL pattern:
/locations/[node:title]
2.6 - Camp
The Camp content type is used for adding camp information to the site.
Fields
Name | Machine name | Required | Description |
---|
Title | Drupal’s default | Yes | Title of the camp item. |
Menu links | field_camp_menu_links | Yes | Link field with multiple values, that should have the Title and Link field. Based on it, we will complete the Camp Menu. |
Meta Tags | field_meta_tags | No | A meta tags field allows us to provide structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. |
Contact | Field group | | |
Address | field_location_address | Yes | An address field that will provide the ability to add details about the locations. Details to be completed: |
| | | - Address |
| | | - City |
| | | - State |
| | | - Zip Code |
Camp Coordinates | field_location_coordinates | No | Input for providing the latitude and longitude information. |
Phone | field_location_phone | Yes | Input for providing the phone information. |
Fax | field_location_fax | No | Input for providing the fax information. |
Email | field_location_email | No | Input for providing the email information. |
Directions | field_location_directions | No | A link field for adding the directions link. |
Header Area | Field group | | |
Content | field_header_content | No | A paragraph embed field that will allow us to add various flexible content modules from the predefined list of paragraph types. |
Content Area | Field group | | |
Content | field_content | No | A paragraph embed field that will allow us to add various flexible content modules from the predefined list of paragraph types. |
Bottom Area | Field group | | |
Content | field_bottom_content | No | A paragraph embed field that will allow us to add various flexible content modules from the predefined list of paragraph types. |
URL pattern
This content type uses the following URL pattern:
/camps/[node:title]
2.7 - Class
The Class content type is used for adding Classes to the site.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the class item. |
Activity | field_class_activity | No | A reference field for selecting the activity the class belongs to. This field references a taxonomy term from the “Activity” vocabulary. |
Meta Tags | field_meta_tags | No | A meta tags field that allows you to provide structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. This helps with SEO and social sharing. |
Header Area | | | |
Content | field_header_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This allows for rich and structured content within the header. |
Content Area | | | |
Description | field_class_description | No | Text area for the class description/body, using a WYSIWYG editor. A summary is not available for this field. |
Content | field_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This is the main content area for the class. |
Sidebar Area | | | |
Content | field_sidebar_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This is for content that will appear in the sidebar of the class page. |
Bottom Area | | | |
Content | field_bottom_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This is for content that appears at the bottom of the class page, often used for calls to action or related links. |
Note: Fields marked as “Field group” are not actual fields but are used to group the fields in the table for better readability.
URL pattern
The Class content type uses the following URL pattern:
/programs/[program-category]/[activity-category]/[class-title]/class-times
Example:
/programs/adult-programs/yoga/beginner-yoga-class/class-times
Explanation:
/programs
: Base path for program content.[program-category]
: The title of the program category, derived from the field_class_activity
reference field to the Activity taxonomy term, which in turn references the Program taxonomy term: [node:field_class_activity:entity:field_activity_category:entity:field_category_program:entity:title]
.[activity-category]
: The title of the activity category, derived from the field_class_activity
reference field to the Activity taxonomy term: [node:field_class_activity:entity:field_activity_category:entity:title]
.[class-title]
: The title of the class node: [node:title]
./class-times
: A fixed suffix for the class times page.
2.8 - Event
The Event content type is used for adding and managing events on the site.
Fields
Label | Machine Name | Required | Description | Field Settings | Notes |
---|
Title | drupal’s default | Yes | Title of the event. | | |
Sub-title | N/A | No | Subtitle of the event. | Plain text | |
Locations | field_event_location | Yes | Reference field to branch and camp nodes. Allows multiple values. | | Address for the event; can be either a branch or a non-branch location. |
Category | field_event_category | No | Reference field for choosing terms from the “Event Category” vocabulary. Allows multiple values. | | |
Meta Tags | field_meta_tags | No | Allows providing structured metadata and Open Graph meta tags for social networking sites like Facebook, Pinterest, and LinkedIn. | | |
Image | field_event_image | No | Image for the event. Entity reference to a Media bundle. | Media | |
Date | field_event_date | Yes | Uses Drupal’s built-in date/time fields. | | |
Add to Calendar | field_add_to_calendar_link | No | Link to add event to calendar. | Link | |
Body | body | No | Textarea for the event description with WYSIWYG editor, without summary. | | |
Content | field_content | No | Filter list of available layout builder components. | | |
Related Content | field_event_related | No | Reference field for choosing related Event nodes. Allows multiple values. | | |
URL pattern
The Event content type uses the following URL pattern:
/event/[node:title]
2.9 - Facility
Facility content type is used for adding facilities on the site.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the facility item. |
Neighborhood | field_location_area | No | A taxonomy reference field using the Area Vocabulary(area). |
Type | field_facility_type | No | A taxonomy reference field using the “Facility Type” vocabulary. |
Facility Branch | field_facility_loc | No | An entity reference field to reference the related Branch node. |
Meta Tags | field_meta_tags | No | A meta tags field allows us to provide structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. |
Contact | Field group | | |
Address | field_location_address | No | An address field that will provide the ability to add details about the locations. Details to be completed: |
Facility Coordinates | field_location_coordinates | No | Input for providing the latitude and longitude information. |
Phone | field_location_phone | Yes | Input for providing the phone information. |
Fax | field_location_fax | No | Input for providing the fax information. |
Email | field_location_email | No | Input for providing the email information. |
Directions | field_location_directions | No | A link field for adding the directions link. |
Facility Hours | field_branch_hours | No | The facility hours. |
Facility Holiday Hours | field_branch_holiday_hours | No | Any special holiday hours for the facility. |
Content Area | Field group | | |
Content | field_content | No | A paragraph embed field that will allow us to add various flexible content modules, from the predefined list of paragraph types. |
Sidebar Area | Field group | | |
Content | field_sidebar_content | No | A paragraph embed field that will allow us to add various flexible content modules, from the predefined list of paragraph types. |
URL pattern
Content type is using the following pattern:
/facility/[node:title]
2.10 - Landing Page
The Landing Page content type is used for creating landing pages on the site.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the landing page item. |
Layout | field_lp_layout | Yes | Select list with the options:one_column_clean |One Column - Full widthone_column |One Columntwo_column |Two Columnstwo_column_fixed |Two Columns with fixed sidebar (sticky at the top)
|
Meta Tags | field_meta_tags | No | A meta tags field allows us to provide structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. |
Header Area | Field group | | |
Content | field_header_content | No | A paragraph embed field that allows you to add various flexible content modules from the predefined list of paragraph types. |
Content Area | Field group | | |
Content | field_content | No | A paragraph embed field that allows you to add various flexible content modules from the predefined list of paragraph types. |
Sidebar Area | Field group | | |
Content | field_sidebar_content | No | A paragraph embed field that allows you to add various flexible content modules from the predefined list of paragraph types. |
Bottom Area | Field group | | |
Content | field_bottom_content | No | A paragraph embed field that allows you to add various flexible content modules from the predefined list of paragraph types. |
URL pattern
The content type uses the following pattern:
[node:title]
2.11 - Landing Page (Layout Builder)
Landing Page content type is used to add Landing Pages to your website using Layout Builder widgets.
This page is managed with Layout Builder. You may want to uncheck “Published” before creating a page, use the “Layout” tab to build the content, then Publish when the page is complete. See our
User Guide for help. You can also use the “Save and edit layout” button to stay in Layout Builder after saving.
Fields
Label | Machine Name | Required | Description | Field Settings | Notes |
---|
Title | title | Yes | Title of Landing Page | | This is used as the administrative title and may also be displayed on the page, depending on your Layout Builder configuration. |
Metadata | Field group | | | | |
Meta description | field_meta_description | No | Short text used for metatags and cards | Text (plain, long) | A brief and concise summary of the pages content that is a maximum of 160 characters in length. |
Meta image | field_meta_image | No | Media image reference for use in metatags and cards | Entity reference (Media image) | Choose or upload an image to be used as a thumbnail for social sharing and preview cards. |
Meta tags | field_meta_tags | No | Provided by Metatag module. Advanced meta tag configuration. | | This section should not be edited unless you are familiar with meta tags. |
URL pattern
This content type uses the following pattern by default: [node:title]
2.12 - Membership
The Membership content type is used for adding membership information to the site.
Fields
Name | Machine name | Required | Description |
---|
Title | Drupal’s default | Yes | Title of the membership item. |
Description | field_mbrshp_description | Yes | Textarea for the description/body with WYSIWYG, without summary. |
Image | field_mbrshp_image | Yes | Media field to upload the image. |
Membership info | field_mbrshp_info | Paragraph | Paragraph to indicate the location where the membership is available and the URL. |
Location | field_mbrshp_location | No | Select list with locations (branches). Single value. |
Link | field_mbrshp_link | No | Link field to provide the membership redirect URL. |
Join Fee | field_mbrshp_join_fee | No | Dollar value for how much someone has to pay to join. |
Monthly Rate | field_mbrshp_monthly_rate | No | Dollar value for the monthly fee of the membership. |
URL pattern
The content type uses the following pattern for its URLs:
/membership/[node:title]
2.13 - News
The News Post content type is used for adding news posts to the site. News posts are typically displayed in a list or grid format, with the most recent posts appearing first.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the news item. This field is a standard Drupal title field. |
Locations | field_news_location | Yes | Reference field to branch and camp nodes. Allows multiple values, enabling you to associate the news item with multiple locations. |
Category | field_news_category | No | Reference field for choosing a term from the “News Category” vocabulary. Allows multiple values, enabling categorization of the news item. |
Meta Tags | field_meta_tags | No | A meta tags field that allows you to provide structured metadata and Open Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. |
Content Area | Field group | | |
Image | field_news_image | No | Image field for the News item. Entity reference to a Media bundle. This allows you to select an existing image from the media library. |
Description | field_news_description | No | Text area for the description/body with WYSIWYG (What You See Is What You Get) editor, without summary option. |
Content | field_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. |
Sidebar Area | Field group | | |
Related content | field_news_related | No | Reference field for choosing related News nodes. Allows multiple values to link to other relevant news items. |
Content | field_sidebar_content | No | A paragraph embed field that allows you to add various flexible content modules to the sidebar from a predefined list of paragraph types. |
URL pattern
This content type uses the following URL pattern:
/news/[node:title]
The [node:title]
token is replaced with the title of the news item, with spaces replaced by hyphens. For example, a news item with the title “New Branch Opens” would have the URL /news/new-branch-opens
.
2.14 - Program
The Program content type is used for adding Programs to the site.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the program item. |
Meta Tags | field_meta_tags | No | A meta tags field allows us to provide structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. |
Header Area | Field group | | |
Icon | field_program_icon | No | An image field, supporting .svg for uploading the program icon. |
Image | field_program_image | No | An image field, for uploading the program image. |
Color | field_program_color | No | Reference field for choosing a term from the “Color” vocabulary. |
Content | field_header_content | No | A paragraph embed field that allows adding various flexible content modules from a predefined list of paragraph types. If this field is not empty, the image and icon are not displayed on the page. |
Content Area | Field group | | |
Description | field_program_description | No | Text area for the description/body with WYSIWYG, without summary. |
Content | field_content | No | A paragraph embed field that allows adding various flexible content modules from a predefined list of paragraph types. |
Sidebar Area | Field group | | |
Content | field_sidebar_content | No | A paragraph embed field that allows adding various flexible content modules from a predefined list of paragraph types. |
URL pattern
This content type uses the following URL pattern:
/programs/[node:title]
2.15 - Program Subcategory
The Program Subcategory content type is used for adding program subcategories to the site.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the program subcategory item. |
Program | field_category_program | Yes | A reference field for selecting the program. This establishes the parent program for the subcategory. |
Meta Tags | field_meta_tags | No | A meta tags field that allows you to provide structured metadata and Graph meta tags for Facebook, Pinterest, LinkedIn, and other social networking sites. This helps with SEO and social sharing. |
Header Area | Field group | | |
Image | field_category_image | No | An image field for uploading the category image. This image is typically displayed in the header area of the subcategory page. |
Color | field_category_color | No | Reference field for choosing a color term from the “Color” vocabulary. This allows you to visually distinguish subcategories. |
Content | field_header_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This allows for rich and dynamic content within the header area. |
Content Area | Field group | | |
Description | field_category_description | No | A textarea for the description/body of the subcategory, using a WYSIWYG editor and without a summary field. |
Content | field_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This is the main content area of the subcategory page. |
Sidebar Area | Field group | | |
Content | field_sidebar_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This is the content that will appear in the sidebar of the subcategory page. |
Bottom Area | Field group | | |
Content | field_bottom_content | No | A paragraph embed field that allows you to add various flexible content modules from a predefined list of paragraph types. This allows you to add content to the very bottom of the subcategory page. This could be calls to action, related content, or other supplemental information. |
URL pattern
This content type uses the following URL pattern:
/programs/[node:field_category_program:entity:title]/[node:title]
This means that the URL will be constructed using the title of the parent program and the title of the subcategory itself. For example, if the parent program is “Youth Programs” and the subcategory is “Summer Camp”, the URL would be /programs/youth-programs/summer-camp
.
2.16 - Promotion
Promotions are timed pieces of content that allow content editors the flexibility to create a single item that can be placed in multiple locations on the site, without having to duplicate or manage content in multiple locations. This content type is typically not displayed on its own page.
Fields
Name | Machine name | Field type | Required? | Description |
---|
Title | title | Text (plain) | Yes | The main title of the promotion. |
Subtitle | field_subtitle | Text (plain) | No | A secondary title or short description displayed below the main title. |
CTA / link | field_link | Link | No | A call-to-action link that directs users to a specific page or external resource. |
Description | field_promo_description | Text (formatted, long) | No | A longer description providing more details about the promotion. This field supports rich text formatting (e.g., bold, italics, lists, links). |
Image | field_promo_media | Entity reference | Yes | An image associated with the promotion. This is an entity reference to a media item. |
Pages | field_promo_visibility_pages | Text (plain, long) | No | A list of internal page paths where the promotion should be displayed. Use relative paths. One path per line. Use <front> for the front page. |
Promotion Category | field_promo_category | Entity reference | No | A category that classifies the promotion (e.g., “New Product,” “Sale,” “Event”). This is an entity reference to a taxonomy term. |
Promotion Priority | field_promo_priority | List (text) | Yes | Determines the order in which promotions are displayed. Options might include “High,” “Medium,” and “Low.” |
Promotion visibility state | field_promo_visibility_state | List (text) | Yes | Controls whether the promotion is visible or hidden. Options may include “Published”, “Unpublished”. |
URL pattern
Promotions are generally embedded within other pages and do not have their own dedicated URL. Therefore, no URL pattern is defined for this content type.
2.17 - Session
The Session content type is used for adding Sessions to the site. Sessions typically represent events, classes, or other scheduled activities.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the session item. |
Class | field_session_class | Yes | A reference field for selecting the program subcategory or type of session. This allows you to categorize sessions. |
Session Info | Field group | - | - |
Description | field_session_description | No | Textarea for the description/body of the session. Uses a WYSIWYG editor (like CKEditor) without a summary field. |
Gender | field_session_gender | No | Select List with Gender options: Coed, Male, Female. This allows you to specify if the session is intended for a specific gender or is coeducational. |
Online registration | field_session_online | No | Boolean field (checkbox) that determines if a “Register Now” button/link is displayed for the session. |
Ticket required | field_session_ticket | No | Checkbox field to indicate that a ticket is required to attend the session. |
Min Age | field_session_min_age | No | Input field for adding the minimum age allowed to participate in the session. |
Max Age | field_session_max_age | No | Input field for adding the maximum age allowed to participate in the session. |
Registration link | field_session_reg_link | No | A link field containing the URL for session registration. This is used if online registration is handled by a third-party system. |
Membership | Field group | - | - |
In membership | field_session_in_mbrsh | No | Boolean field (checkbox) that indicates whether the session is included in a membership package. |
Member price | field_session_mbr_price | No | Input field for specifying the price for members. |
Non Member Price | field_session_nmbr_price | No | Input field for specifying the price for non-members. |
Location | Field group | - | - |
Location | field_session_location | Yes | A reference field for selecting the branch or camp where the session is held. This should link to a location content type. |
Physical Location | field_session_plocation | No | A reference field for selecting the specific facility (e.g., room, gym) within the branch or camp where the session takes place. This should link to a facility content type. |
Time | Field group | - | - |
Exclusions | field_session_exclusions | No | A date field that identifies specific dates on which the session will not be held, even if it’s normally scheduled. Supports multiple values. Should be a single date field with the ’end date’ option enabled. Its widget should be adjusted to not show period end date, but show period end time (to keep period start/end date equal). |
Time | field_session_time | Paragraph | Session schedule defined using a Paragraph content type. |
Date & Time | field_session_time_date | No | A Drupal date/time field. Should be a single date field with both ’end date’ and ’end time’ options enabled. |
Days | field_session_time_days | No | Checkboxes with the following values:- sunday|Sunday
- monday|Monday
- tuesday|Tuesday
- wednesday|Wednesday
- thursday|Thursday
- friday|Friday
- saturday|Saturday
Supports multiple values, allowing you to select all days on which the session occurs. |
URL pattern
No dedicated URL pattern is defined for the Session content type by default. The intention is that this content type may not be directly accessed by end-users via a dedicated URL.
2.18 - Social Post
The Social Post content type is used for adding social media posts to the site. Social Posts are typically fetched from social networks using a module like the
Social Feed Fetcher.
Fields
Name | Machine name | Required | Description |
---|
Title | drupal’s default | Yes | Title of the social post content item. |
ID | field_id | Yes | Post ID in the social network. This is a system field used by the post fetcher to identify the social post. |
Image | field_sp_image | No | Image field for saving the post image. Supports jpg , png , and gif formats. |
Link | field_link | No | Contains the link to the original post on the social network. |
Platform | field_platform | Yes | The name of the platform where the post was imported from (e.g., Facebook, Twitter, Instagram). |
Post | field_post | Yes | The text content of the post. May contain HTML markup. |
Posted | field_posted | Yes | The date and time when the post was originally posted on the social network. |
URL pattern
The content type uses the following URL pattern:
/social_post/[node:title]
3 - Layout Builder
These custom block types exist to support page building with Layout Builder. Blocks are boxes of content rendered into a region of a web page. Content blocks are blocks whose content you can edit.
Global Fields
These fields are reused across many of the below components.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | field_section_heading | Text (plain) | No | 1 | | | H2 |
Section subheading | field_section_subheading | Text (plain, long) | No | 1 | | | H3 |
Accordion
Expandable pairs of question/answer or header/section fields.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Accordion item | field_block_item | Entity reference | No | Unlimited | | Bundle: accordion_item | |
FAQ? | field_is_faq | Boolean | No | 1 | If this section contains Frequently Asked Questions, check this box to output them as structured data… | | |
Accordion Item
- Machine name:
accordion_item
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Heading | field_title | Text (plain) | Yes | 1 | | | H4 |
Body | body | Text (formatted, long, with summary) | Yes | 1 | | | WYSIWYG |
Branch Amenities
Display of all amenities available at a branch location.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Amenity name | field_amenity_name | Entity reference | Yes | Unlimited | | Taxonomy | |
Cards
Flexible card-style components that allow up to 4 cards to display across a page depending on the chosen layout.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Section link | field_cta | Link | No | 1 | | | |
# of columns | field_columns | List (text) | Yes | 1 | | | |
Card items | field_block_item | Entity reference | No | 4 | | Bundle: card_item | |
Card Item
Machine name: card_item
The Card item block is referenced by the Cards block.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Heading | field_title | Text (plain) | Yes | 1 | | | H4 |
Image | field_media | Entity reference | No | 1 | | | |
Topic tag | field_topic_tag | Entity reference | No | 1 | | Bundle: blog_category, news_category | |
Description | field_body | Text (plain, long) | No | 1 | | | |
Link | field_cta | Link | No | 1 | | | |
Carousel
A full-width display with multiple sets of a header, description, and call to action overlaid on top of an image.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Carousel items | field_block_item | Entity reference | No | 6 | | Bundle: carousel_item | |
Carousel Item
Machine name: carousel_item
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Heading | field_title | Text (plain) | No | 1 | | | H4 |
Image | field_media | Entity reference | Yes | 1 | | | |
Description | field_description | Text (formatted, long) | No | 1 | | | |
Link | field_cta | Link | No | 1 | | | |
Code
- Machine name:
ws_code_block
- Project:
ws_code_block
- Designs: This block provides no additional presentation outside of the embedded content.
Embed unfiltered HTML code in a page.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Code | field_code | Text (formatted, long) | Yes | 1 | | Text format: “Code” | |
Grid CTA
Sets of content with a headline, description, and link displayed in 2 to 4-item wide rows, with the option to include icons or images.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Grid CTA section link | field_section_cta_link | Link | No | 1 | A link button to be displayed below the grid content | | |
# of columns | field_columns | List (text) | Yes | 1 | | | Allows 2-4 columns, defaults to 4. |
Grid item | field_block_item | Entity Reference | Yes | 4 | | Bundle: grid_item | |
Grid Item
Machine name: grid_item
The Grid Item block is referenced by the Grid CTA component.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Heading | field_title | Text (plain) | No | 1 | | | H4 |
Description | field_description | Text (formatted, long) | No | 1 | | | |
Media | field_media | Entity reference | No | 1 | | | |
Link | field_cta | Link | No | 1 | | | |
Hero Banner
A full-width, almost full-height display with a header, description, and call to action overlaid on an image.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Heading | field_heading | Text (plain) | Yes | 1 | | | H2 |
Description | field_description | Text (formatted, long) | No | 1 | | | |
Media | field_media | Entity reference | No | 1 | | Bundle: Image, Local Video, Video | |
Link | field_link | Link | No | 1 | | | |
Partners
List of multiple partner / sponsor logos.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Partner items | field_partner_items | Entity reference revisions | No | Unlimited | | Bundle: lb_partner_item | |
Partner Item
Machine Name: lb_partner_item
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Heading | field_item_heading | Text (plain) | Yes | 1 | | | H4 |
Image | field_item_image | Entity reference | Yes | 1 | | | |
Ping-pong
Usually paired sets of full-width page components that include media, header, description, and call to action arranged horizontally.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Heading | field_item_heading | Text (plain) | No | 1 | | | H4 |
Description | field_item_description | Text (formatted, long) | No | 1 | | | WYSIWYG |
Link | field_item_link | Link | No | 2 | The first will use the primary style and the second, secondary. | | |
Image | field_item_image | Entity reference | No | 1 | | | |
Image position | field_item_image_position | List (text) | Yes | 1 | Places the image on this side of the page in the full-width display. Image will stack above text at narrow widths. | | |
A title, headline, description, and link that usually display in the right or left sidebar.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Title | field_title | Text (plain) | Yes | 1 | | | |
Body | body | Text (formatted, long, with summary) | No | 1 | | | |
Image | field_image | Entity reference | No | 1 | | Bundle: Image | |
Link | field_link | Link | No | 1 | | | |
Related Articles
Component for displaying related articles within a page.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Component for displaying related events within a page.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Simple Content
Allows users to be able to view responsive tables within a page.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Body | body | Text (formatted, long, with summary) | No | 1 | | | Allows for responsive tables to be placed in the body. |
A simple 1-level sidebar menu that can display in either the right or left sidebar area.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Icon | field_icon | Entity reference | No | 1 | | Bundle: Image | |
Links | field_links | Link | Yes | Unlimited | | | |
Staff
Displays simple staff member info cards with image, name, title, email
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Staff items | field_staff_items | Entity reference revisions | No | Unlimited | | Bundle: lb_staff_item | |
Staff Item
Machine name: lb_staff_item
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Name | field_item_name | Text (plain) | Yes | 1 | | | H4 |
Image | field_item_image | Entity reference | Yes | 1 | | | If no image uploaded, utilize default |
Job title | field_item_job_title | Text (plain) | Yes | 1 | | | |
Email | field_item_email | Text (formatted, mailto) | Yes | 1 | | | Clicking on email should open users default email client |
Statistics
Infographic-like display that highlights relevant statistics to users.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
# of columns | field_columns | List (text) | Yes | 1 | | | |
Section link | field_cta | Link | No | 1 | | | |
Statistics item | field_block_item | Entity reference | No | Unlimited | | Bundle: statistics_item | |
Statistics Item
Machine name: statistics_item
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Number value | field_subtitle | Text (plain) | Yes | 1 | | | |
Description | field_description | Text (plain) | No | 1 | | | |
Tabs
Gives users the ability to switch page views by selecting tabs across the top of the page instead of having to navigate to a new page.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Tab item | field_block_item | Entity reference | No | Unlimited | | Bundle: tab_item | |
Tab Item
Machine name: tab_item
The Tab Item block is referenced by the Tabs block.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Heading | field_heading | Text (plain) | Yes | 1 | | | H4 |
Body | field_description | Text (formatted, long) | No | 1 | | | WYSIWYG |
Testimonials
Display of short testimonials or quotes.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Section heading | (inherit) | | | | | | H2 |
Section subheading | (inherit) | | | | | | H3 |
Testimonial items | field_testimonial_items | Entity reference revisions | No | 4 | | Bundle: lb_testimonial_item | |
Testimonial Item
Machine Name: lb_testimonial_item
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Name | field_item_name | Text (plain) | Yes | 1 | | Firstname, Lastname | H4 |
Image | field_item_image | Entity reference | Yes | 1 | | | If no image uploaded, utilize default |
Quote | field_item_quote | Text (plain) | Yes | 1 | | | |
Embed an existing webform on a page.
Label | Machine Name | Type | Required | Cardinality | Help text | Field Settings | Notes |
---|
Form title | (inherit) | | | | | | |
Form subtitle | (inherit) | | | | | | |
Webform | field_webform | Webform | Yes | 1 | | | |
4 - Media
Core media items include audio, images, documents, and videos. You can add other media types, such as social media posts, through the use of contributed modules. Media items may be files located in your site’s file system or remote items referenced by a URL. Media items are content entities, and they are divided into media types (which are entity sub-types); media types can have fields. Refer to the
Content Structure documentation for more information on content entities and fields.
The media library is a visual user interface for managing and reusing media items. Add media items to content using Media reference fields and the Media library field widget.
What is an Image Style?
An image style is a set of processing steps, known as effects, that can be applied to images. Examples of effects include scaling and cropping images to different sizes. Responsive image styles can associate image styles with your theme’s size breakpoints. This allows serving images sized for the browser width.
The following modules provide media-related functionality:
- Media items and media types are managed by the core Media module.
- The core Media module provides a Media reference field to add media to content entities. The core File and Image modules also provide reference fields. It is recommended to use the Media reference field because it is more versatile.
- The core Media Library module provides the media library and the Media library field widget. With this module installed, the Media library field widget becomes the default widget for editing Media reference fields.
- The core Image module provides a user interface for defining image styles. The core Responsive Image module provides responsive image styles. Using the core Breakpoint module and a breakpoint-enabled theme, these responsive styles can serve images sized for the browser.
See the related topics listed below for specific tasks.
Additional Resources
4.1 - WYSIWYG View Modes
The following view modes are available for embedding media assets within a WYSIWYG editor, such as CKEditor 5. These view modes offer different display options for media assets, allowing content creators to choose the most appropriate presentation for their content.
View Modes
Name | Machine name | Description |
---|
Full | embedded_full | Displays the media asset at its full width within the available container. |
Half | embedded_half | Displays the media asset at half its original width, typically with alignment options (left or right) to control its placement. |
Link | embedded_link | Displays a simple link to the media asset, directing the user to the original file. |
Bundle Details
The display of each media asset type (Image, Video, Document) varies depending on the selected view mode. The following outlines the specific rendering for each bundle:
Image
- Full & Half View Modes: Images are displayed using the
<img>
tag with appropriate CSS classes applied for styling and responsiveness. The specific classes may vary depending on the theme and styling configuration. - Link View Mode: A hyperlink (
<a>
tag) is generated, pointing to the original image file. The link includes target="_blank"
to open the image in a new tab or window.
Video
- Full & Half View Modes: Videos are displayed as embedded video players, likely using the
<video>
tag or an <iframe>
to embed from a video hosting platform. Appropriate CSS classes are applied for styling. - Link View Mode: A hyperlink (
<a>
tag) is generated, pointing to the original video file. The link includes target="_blank"
to open the video in a new tab or window.
Document
Full & Half View Modes: Documents are displayed using an <iframe>
tag. The src
attribute of the <iframe>
points to a service like Google Docs Viewer, which renders the document within the iframe. Replace URL
with the actual URL of the document. Appropriate CSS classes are applied for styling.
<iframe src="//docs.google.com/gview?url=URL&embedded=true" frameborder="0"></iframe>
Link View Mode: A hyperlink (<a>
tag) is generated, pointing to the original document file. The link includes target="_blank"
to open the document in a new tab or window.
5 - Paragraphs
Welcome to YMCA Website Services Paragraphs.
Paragraphs are content components, aligning with
component-based design principles. Within the YMCA Website Services architecture, paragraphs are based on the
Paragraphs Drupal module. This module enables the creation of Paragraphs entities.
The core idea is to provide a user-friendly widget for adding predefined content blocks directly within a page or other content item, without needing to reference external entities. It’s important to note that paragraphs are not intended as reusable content types. For reusable content, consider using blocks
or other entities
within Drupal.
Paragraphs enhance the user experience by offering a convenient and structured way to build content. They allow content editors to create unique layouts for their pages. Each paragraph represents a distinct content section, complete with its own styling, functionality, and fields.
Here’s a breakdown of key aspects:
Paragraphs Module: Facilitates the creation of paragraph entities within Drupal.
Component-Based Design: Paragraphs align with the principle of building interfaces from independent, reusable components.
User Experience (UX): Paragraphs are designed to make content creation more intuitive and efficient.
Non-Reusable Types: Paragraphs are not designed to be reused across multiple content items. Instead, look at Drupal blocks or entities.
Paragraphs Types: Paragraphs are pre-defined sets of fields that are made available to the content editors. These are configured under Structure > Paragraphs Types.
To get started with Paragraphs:
- Install the Paragraphs module.
- Create Paragraphs types.
- Add a Paragraph field to a content type.
- Begin creating content and adding paragraphs.
5.1 - 1 Column
The 1 Column paragraph type allows you to create a single-column layout within your content.
Fields
Name | Machine name | Required | Description | Notes |
---|
Line Above | field_prfg_display_line_above | No | Display a line above the column. | |
Column | field_prgf_1c_column | No | Enter the main content for the single column. This field typically supports rich text. | |
Paragraph Title | field_prgf_1c_title | No | Enter a title to display at the top of the 1-column paragraph. | |
Paragraph Description | field_prgf_1c_description | No | Enter a description to display below the paragraph title. | |
5.2 - 2 Columns
The 2 Columns paragraph type allows you to create a paragraph with two columns for content. This is useful for displaying related information side-by-side or creating visually appealing layouts.
Fields
Name | Machine name | Required | Description | Notes |
---|
Line Above | field_prfg_display_line_above | No | Display a horizontal line above the columns. | |
Left Column | field_prgf_2c_left | No | Content for the left column. | Supports text, images, and other embedded content. |
Right Column | field_prgf_2c_right | No | Content for the right column. | Supports text, images, and other embedded content. |
5.3 - 3 Columns
The 3 Columns paragraph type allows you to create a paragraph with three distinct columns of content. This paragraph type is useful for displaying information in a structured and visually appealing manner.
Fields
Name | Machine name | Required | Description | Notes |
---|
Line Above | field_prfg_display_line_above | No | Display a line above the column. | |
Left Column | field_prgf_3c_left | No | Enter the content for the left column. | |
Center Column | field_prgf_3c_center | No | Enter the content for the center column. | |
Right Column | field_prgf_3c_right | No | Enter the content for the right column. | |
Paragraph Title | field_prgf_title | No | Enter a title to display at the top of the 3 columns paragraph. | |
5.4 - 4 Columns
The 4 Columns paragraph type allows you to create a content block with four columns of information. This is useful for displaying related content side-by-side.
Fields
Name | Machine name | Required | Description | Notes |
---|
Line Above | field_prfg_display_line_above | No | Display a line above the column. | Use this to visually separate this paragraph from the content above it. |
First Column | field_prgf_4c_1st | No | Enter the content for the first column. | Supports text, images, and other embedded content. |
Second Column | field_prgf_4c_2nd | No | Enter the content for the second column. | Supports text, images, and other embedded content. |
Third Column | field_prgf_4c_3rd | No | Enter the content for the third column. | Supports text, images, and other embedded content. |
Fourth Column | field_prgf_4c_4th | No | Enter the content for the fourth column. | Supports text, images, and other embedded content. |
Button | field_prgf_4c_button | No | Button with link to display under the 4-column paragraph. | Use this to add a call to action or link to more information related to the content. |
Paragraph Title | field_prgf_title | No | Enter a title to display at the top of the 4-column paragraph. | This provides a clear heading for the entire paragraph. |
Paragraph Description | field_prgf_description | No | Enter a description to display under the 4-column paragraph title. | Use this to provide context or an overview of the content within the four columns. |
5.5 - All Amenities
This paragraph displays a list of amenities, typically in a table view. It’s useful for showcasing available features or services.
Fields
Name | Machine name | Required | Description |
---|
All amenities | field_field_prgf_amnts_view | No | Predefined reference to a view that displays all amenities. Configure this view to control which amenities are shown and how they are formatted. |
Title | field_prgf_title | No | Enter the title that will be displayed at the top of the paragraph. This provides context for the list of amenities. |
Important Considerations:
- View Configuration: The “All amenities” field relies on a pre-existing view. Ensure this view is properly configured to display the desired amenity information.
- Paragraph Usage: This paragraph type is generally intended for use within a larger page structure, like a landing page or a branch details page.
- Alternative: Consider using “Branch Amenities” block if you want to show the amenities for the current branch.
5.6 - Banner
The Banner paragraph type is used to display eye-catching content, often at the top of a page or section. It typically includes a headline, description, image, and a call to action link.
Fields
Name | Machine name | Required | Description | Notes |
---|
Headline | field_prgf_headline | Yes | The main heading of the banner. This should be concise and attention-grabbing. | Plain text, maximum 255 characters |
Color | field_prgf_color | Yes | A reference field that allows you to select a color from the “Color” vocabulary. This color is often used as a background or accent color for the banner. | Choose a term from the “Color” vocabulary |
Image | field_prgf_image | No | An entity reference to a media image. This image should be visually appealing and relevant to the banner’s content. | Single value |
Description | field_prgf_description | No | A WYSIWYG field where you can add descriptive text to the banner. Use this to provide more context or details about the banner’s topic. It is recommended to avoid using a summary for this field. | |
Link | field_prgf_link | No | A link field that stores both internal and external links. Use this to direct users to relevant pages or resources. This can be a call to action. | Use for internal and external links |
5.7 - Blog Posts Listing
This paragraph is dynamic and renders the latest blog posts, utilizing exposed filters for enhanced content discovery. It’s based on the openy_prgf_blog_listing
module.
Key Features:
- Filtering: Allows users to filter blog posts based on:
- Location
- Category
- Text (Search Keywords)
- Sticky at Top: Supports the “sticky at top” functionality to highlight important posts.
- Ordering: Orders blog posts by published date, displaying the newest posts first.
- Views Integration: Leverages Drupal’s Views module for flexible content display and filtering. The exposed filters are part of the View configuration.
- Infinite Scroll: Supports the
views_infinite_scroll
module for a better user experience.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block that provides the blog post listing. It should have a default value and ideally be hidden in the form display to prevent accidental modification. The view should be configured to use exposed filters for Location, Category, and Text. |
Module Dependencies:
openy_prgf_blog_listing
views_infinite_scroll
Related Paragraphs:
5.8 - Branches Popup (All)
This dynamic paragraph renders the locations selection popup, based on the current node. It’s typically used to allow users to select a branch or location from a popup window. This selection can then influence other elements on the page, such as filtering schedules or classes.
Relates to:
- [Schedule search list](Schedule search list.md)
- [Classes Listing](Classes Listing.md)
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block that provides the location selection options. It should have a default value configured and is typically hidden in the form display to prevent direct user modification. This field is the key to connecting the paragraph to the actual location data. |
Usage
This paragraph is often used in conjunction with other paragraphs and blocks to create a location-aware experience. For example, it might be used on a page with a schedule search to allow users to filter the schedule by location.
The openy_branch_selector
module is often used to provide the functionality for selecting and saving a user’s preferred branch. The selected branch can then be used to pre-populate location filters and customize the user’s experience.
The specific appearance and behavior of the popup are determined by the view/block referenced in the field_prgf_block
field. This allows for a high degree of customization to match the specific needs of the site.
5.9 - Branches Popup (Class)
This dynamic paragraph renders the location selection popup based on the current node. It’s typically used to allow users to select a location from a list of branches.
Relates to:
- [Class Sessions](Class Sessions.md)
- [Class Location](Class Location.md)
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to a View or a Block plugin. This field should have a default value configured and is typically hidden in the form display for content editors. |
5.10 - Categories Listing
This is a dynamic paragraph that renders all published categories associated with the current program page.
It typically includes a “sticky at the top” option and orders items based on their published date (newest at the top).
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. This field should have a default value and is typically hidden in the form display. |
Note: The Categories Listing paragraph type displays taxonomy terms. Taxonomy terms are categorized under: plain text, number, reference, date and time and general.
5.11 - Class Location
This dynamic paragraph renders the location’s “class location” view mode based on the location
URL query parameter with a valid ID. This paragraph is typically used on class pages to display location-specific information.
Context:
- This paragraph is used to display location information, such as address, phone number, and hours, for a specific class.
- The “class location” view mode defines how the location information is displayed.
Relates to [Branches Popup (Class)](Branches Popup (Class).md).
- When the page has a
location
parameter, the Branches Popup paragraph will make an “Edit” link on this paragraph visible. That link triggers the Branches Popup to open, allowing the user to select a different location.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. Should have a default value and should be hidden in the form display. This field determines which block is rendered within the paragraph. The referenced block provides the actual content and formatting for the location information. Consider using a view block to display dynamic content related to the location. |
5.12 - Class Sessions
This dynamic paragraph renders class session instances based on the URL query parameter location
with a valid ID.
Relates to [Branches Popup (Class)](Branches Popup (Class).md).
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. Should have a default value and should be hidden in form display. |
Displayed Table
The following fields are displayed in a table format:
- Location: Displayed unless
&location=%
is present in the URL, in which case it is hidden. - Time + Date
- Registration: A link to the registration page.
- Details:
- Online registration information
- Ticket requirement status
- Membership eligibility
- Age: Minimum and maximum age range for the class.
Use Cases
These use cases describe the behavior of the Class Sessions paragraph in different scenarios, specifically regarding location filtering.
Use case 3: Class page WITHOUT location popup
Location Specified in URL
1 Location in specified URL
- When a Class page without a location popup is opened.
- And the URL contains
location=%
. - The system skips any existing cookie values.
- The class session results are filtered based on the location specified in the URL.
- A location teaser is displayed in the sidebar.
Preferred Branch Empty or Selected, No Location in URL
2 Preferred branch is empty and no location in URL or Preferred branch is selected and no location in URL
- When a Class page without a location popup is opened.
- And either:
- No preferred branch is selected.
- A preferred branch is selected, but the URL does not contain
location=%
.
- The class session results include all branches.
- “All locations…” is displayed in the sidebar.
Use case 4: Class page WITH location popup
Location Specified in URL
1 Location in specified URL
- When a Class page with a location popup is opened.
- And the URL contains
location=%
. - The system skips any existing cookie values.
- The class session results are filtered based on the location specified in the URL.
- A location teaser is displayed in the sidebar.
- The location teaser in the sidebar includes an “Edit” link that opens the location popup.
Preferred Branch Empty or Selected, No Location in URL
2 Preferred branch is empty and no location in URL or Preferred branch is selected and no location in URL
- When a Class page with a location popup is opened.
- And either:
- No preferred branch is selected.
- A preferred branch is selected, but the URL does not contain
location=%
.
- The class session results include all branches.
- “All locations…” is displayed in the sidebar.
- The location popup is displayed, unless only one location is associated with the class.
5.13 - Classes Listing
Displays published classes and provides filtering options.
The Classes Listing paragraph displays all published classes, grouped by activity.
The Classes Listing Filters provide a filter form with the following fields:
- Location
- Program
- Sub-program
- Activity
Relates to [Branches Popup (All)](Branches Popup (All).md).
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. A default value should be set, and this field should be hidden in the form display. |
Use Cases
1.1 Preferred branch is selected and no location in URL
- When I open a Program subcategory page with the Classes Listing paragraph WITHOUT a location popup on the page.
- And I have a preferred branch set (via cookie).
- And I don’t have
location=%
in the URL. - Then the filter by location should be pre-defined based on the cookie value.
- And the results should be filtered accordingly.
1.2 Preferred branch is empty and no location in URL
- When I open a Program subcategory page with the Classes Listing paragraph WITHOUT a location popup on the page.
- And I don’t have a preferred branch set (cookie is empty).
- And I don’t have
location=%
in the URL. - Then the filter by location should show “All”.
- And the results should be shown for all branches.
1.3 Location specified in URL
- When I open a Program subcategory page with the Classes Listing paragraph WITHOUT a location popup on the page.
- And I have
location=%
in the URL. - Then the preferred branch cookie should be ignored, regardless of its value.
- And the filter by location should show the branch from the URL.
- And the results should be filtered accordingly.
2.1 Preferred branch is selected and no location in URL
- When I open a Program subcategory page with the Classes Listing paragraph WITH a location popup on the page.
- And I have a preferred branch set (via cookie).
- And I don’t have
location=%
in the URL. - Then the location popup shouldn’t be shown.
- And the filter by location should be pre-defined based on the cookie value.
- And the results should be filtered accordingly.
2.2 Preferred branch is empty and no location in URL
- When I open a Program subcategory page with the Classes Listing paragraph WITH a location popup on the page.
- And I don’t have a preferred branch set (cookie is empty).
- And I don’t have
location=%
in the URL. - Then the filter by location should show “All”.
- And the results should be shown for all branches.
- And the location popup should be shown.
2.3 Location specified in URL
- When I open a Program subcategory page with the Classes Listing paragraph WITH a location popup on the page.
- And I have
location=%
in the URL. - Then the preferred branch cookie should be ignored, regardless of its value.
- And the location popup shouldn’t be shown.
- And the filter by location should show the branch from the URL.
- And the results should be filtered accordingly.
5.14 - Code
The Code paragraph type allows you to embed code snippets, or even embed content from other websites such as YouTube videos. It leverages the Code block type for its functionality.
Fields
Name | Machine name | Required | Description |
---|
Code | field_prgf_code_block | Yes | Block reference to a Code block. You can create a new Code block directly from the paragraph edit screen, or select an existing one from the library. The Code block will determine the actual content displayed. |
5.15 - Featured Blog Posts
The “Featured Blog Posts” paragraph type displays a listing of featured blog posts. It utilizes the openy_prgf_featured_blogs
module.
Fields
Name | Machine Name | Required | Description |
---|
Headline | field_prgf_headline | No | Headline of the banner. This is a simple text field. |
Blog Posts | field_fblog_posts | Yes | Multiple values. A reference field that links to Blog posts. The blog posts are sourced from nodes of the “Blog” content type. |
- Module:
openy_prgf_featured_blogs
- Description: Provides a dynamic paragraph that renders a featured blog posts listing.
- Dependencies:
drupal:field
drupal:node
openy_node_blog:openy_node_blog
openy_prgf:openy_prgf
paragraphs:paragraphs
Templates
The appearance of this paragraph can be customized via Twig templates. The following templates are used by default, and can be overridden in your theme:
themes/contrib/openy_rose/templates/paragraph/paragraph--featured-blogs--default.html.twig
themes/contrib/openy_lily/templates/paragraphs/paragraph--featured-blogs--default.html.twig
themes/contrib/openy_carnation/templates/paragraph/paragraph--featured-blogs--default.html.twig
5.16 - Featured Content
The Featured Content paragraph type is used to create dynamic listings of content with various grid layouts. It’s part of the openy_prgf_featured_content
module.
Fields
Name | Machine name | Required | Description |
---|
Headline | field_prgf_headline | No | Headline of the featured content. |
Description | field_prgf_description | No | Text area for the description/body with WYSIWYG, without summary. |
Link | field_prgf_link | No | Link field that supports internal and external URLs. |
Style | field_prgf_grid_style | Yes | Select list defining the number of items per row: 2 : 2 items, 3 : 3 items, 4 : 4 items. |
Column description | field_prgf_fc_clm_description | No | Multiple values. Text area for column descriptions with WYSIWYG, without summary. |
5.17 - Featured Highlights
The Featured Highlights paragraph type provides a way to display specific content blocks in a grid layout, with options for 2, 3, or 4 blocks per row.
Fields
Name | Machine name | Required | Description |
---|
Title | field_prgf_title | No | Optional paragraph title displayed above the grid of blocks. |
Style | field_prgf_grid_style | Yes | Determines the number of blocks displayed per row. A select list with the following values: 2 : 2 items per row, 3 : 3 items per row, 4 : 4 items per row. |
Featured Highlights block | field_prgf_block_ref_unlim | Yes | References blocks to be displayed in the grid. You can create a new block or select an existing block. Allowed block types: Featured Highlight Block, Basic Block, Simple Block, and Date block. The “Featured Highlight Block” provides a title, link, image, and description for each item. |
5.18 - Featured News Posts
The Featured News Posts paragraph type displays a set of news articles. It allows content editors to highlight timely and relevant news items on a page. This paragraph leverages the openy_prgf_featured_news
module.
Fields
Name | Machine name | Required | Description |
---|
Headline | field_prgf_headline | No | Headline for the featured news section. This will appear above the linked news posts. |
News Posts | field_fnews_posts | Yes | Multiple values. References existing News posts (nodes of type “News”). The referenced news posts will be displayed in this section. |
Usage
- When creating or editing a page or content type that supports paragraphs, select the “Featured News Posts” paragraph type.
- Enter a “Headline” for the section (optional).
- In the “News Posts” field, select one or more existing News posts. Use the autocomplete functionality to search for news posts by title.
- Save the paragraph and the parent content.
The selected news posts will now be displayed on the page, under the specified headline. The display of each news post will use the “teaser” view mode.
5.19 - Gallery
The Gallery paragraph type is used to display a collection of images, often with accompanying text and links.
Fields
Name | Machine Name | Required | Description |
---|
Headline | field_prgf_headline | Yes | Headline of the gallery. Plain text. |
Description | field_prgf_description | No | WYSIWYG field without summary. Allows for rich text formatting to describe the gallery. |
Link | field_prgf_link | No | Link field for internal and external URLs. Can be used to link to more information. |
Images | field_prgf_images | No | Entity reference to media images. Supports multiple images in the gallery. |
5.20 - Grid columns
This paragraph type is used for the field_grid_columns
within the Grid Content paragraph. It defines the structure and fields for individual columns within a grid layout.
Fields
Name | Machine name | Required | Description |
---|
Description | field_prgf_grid_clm_description | No | Textarea for the column’s description or body content. Supports WYSIWYG editing, but does not include a summary field. |
Headline | field_prgf_clm_headline | No | Headline for the grid content within the column. |
Icon | field_prgf_clm_icon | No | Entity reference to a media asset, typically an image. Recommended to allow uploading of SVGs for scalability. |
Icon class | field_prgf_clm_class | No | Input field for adding
Font Awesome icon classes (e.g., flag , car , info ). Overrides the image specified in the Icon field. |
Link | field_prgf_clm_link | No | Link field that supports both internal and external URLs. |
5.21 - Grid Content
The Grid Content paragraph type is used to create grid layouts within stories.
Fields
Name | Machine name | Required | Description |
---|
Style | field_prgf_grid_style | Yes | Select list with the following values: 2 : 2 items per row, 3 : 3 items per row, 4 : 4 items per row. This determines the number of columns in the grid. |
Content | field_grid_columns | Paragraph | Grid columns. This field references the Grid columns paragraph type, allowing you to add individual columns to the grid. |
Description | field_prgf_grid_clm_description | No | Textarea for the column description/body. Supports WYSIWYG editing, but without a summary option. |
Headline | field_prgf_clm_headline | No | Headline for the grid content column. |
Icon | field_prgf_clm_icon | No | Entity reference to a media asset, typically an SVG image. Allows uploading of new SVG files. |
Icon class | field_prgf_clm_class | No | Input field for adding
Font Awesome icon classes (e.g., flag , car , info ). This will override the image Icon. |
Link | field_prgf_clm_link | No | Link field that supports both internal and external URLs. |
5.22 - Group Schedules
This is a dynamic paragraph that renders group schedules from the GroupEx Pro system. It leverages the openy_prgf_group_schedules
module. This paragraph type allows content editors to embed schedules directly within content, providing users with up-to-date class and activity information.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block that displays the GroupEx Pro schedule. A default value should be set and is configurable in the form display. |
5.23 - Latest Blog Posts
This paragraph is a dynamic element that displays the most recent blog posts. It’s designed to showcase content that is promoted to the front page.
Key features:
- Sticky at the top: This ensures the most important blog posts remain visible.
- Order: Items are ordered by published date, with the newest posts appearing first.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | This field holds a block reference to the view/block that provides the blog post listing. It is intended to have a default value set and is typically hidden from the form display to simplify content creation and prevent accidental modification of the listing source. |
5.24 - Latest Blog Posts (Branch)
This dynamic paragraph renders the latest blog posts associated with a specific branch. It displays posts in chronological order, with the newest posts at the top, and utilizes the “sticky at the top” option to highlight important content.
Functionality
This paragraph type automatically filters and displays blog posts based on the branch context in which it is placed. For example, if this paragraph is added to a “Downtown YMCA” branch page, it will only display blog posts associated with the “Downtown YMCA” branch. If placed on a non-branch page, only the headline will be visible.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. This field should have a default value and be hidden in the form display. It determines the view or block used to render the blog posts. |
5.25 - Latest Blog Posts (Camp)
This paragraph dynamically renders the latest blog posts associated with a specific camp. It displays posts in reverse chronological order (newest first).
Functionality
- Filtering: Displays only blog posts associated with the current camp. If placed on a non-camp page, only the title will render.
- Ordering: Blog posts are ordered by published date, with the newest posts appearing at the top.
- Styling: Blog posts are displayed in a card format.
Usage
This paragraph is typically used in the content area or bottom area of a Camp page to showcase relevant blog content. To use it, select “Latest Blog Posts (Camp)” from the paragraphs dropdown, and enter a header title.
Supported Content Types
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. This field should have a default value and is typically hidden in the form display. |
5.26 - Latest News Posts
This paragraph type dynamically renders the latest news posts. It is typically used to display news promoted to the front page, ordering them by published date with the newest at the top. The “sticky at the top” option can be used to highlight certain posts.
This paragraph leverages a block reference to display content.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | A block reference to a view or block. A default value should be configured, and the field should be hidden in the form display. This block will contain the actual list of news posts. |
5.27 - Latest News Posts (Branch)
The “Latest News Posts (Branch)” paragraph type is a dynamic element that displays the most recent news articles associated with a specific branch location. It’s designed to highlight timely and relevant information, ensuring that users are presented with the newest content first.
This paragraph automatically orders news items by their published date, with the most recent articles appearing at the top. Additionally, it utilizes a “sticky at the top” feature, which can be configured in the associated View to keep specific, important news posts prominently displayed.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | This field is a block reference to a View block that lists news posts. The View should have a default value set and is typically hidden in the form display to simplify content editing. The view should filter by branch. |
Module Dependencies
This paragraph type is provided by the openy_prgf_news_branch
module, which has the following dependencies:
field
: Part of Drupal core.node
: Part of Drupal core.openy_loc_branch
: Open Y Branch Location module.openy_node_news
: Open Y News Node module.openy_prgf
: Open Y Paragraphs base module.paragraphs
: Paragraphs module for creating structured content.plugin
: Part of Drupal core.user
: Part of Drupal core.views
: Part of Drupal core.views_infinite_scroll
: Views Infinite Scroll module for paginating results.
5.28 - Latest News Posts (Camp)
This paragraph type dynamically renders the latest news posts associated with a specific camp. It displays news articles in reverse chronological order (newest first) and can utilize a “sticky” option to highlight certain posts at the top of the list.
Functionality
This paragraph is designed to be placed on a Camp page. When placed on a Camp page, it will display only news posts associated with that specific camp. If placed on a non-Camp page, it will display only the title (if one is configured).
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block that displays the news posts. A default value should be configured for this field, and it should typically be hidden in the form display to prevent accidental modification. |
5.29 - Limited Time Offer
This Paragraph type is used to add a limited-time offer section to a page, often the home page, and is based on a Landing Page Content Type.
Fields
Name | Machine name | Required | Description |
---|
Subtitle | field_lto_subtitle | No | Enter the subtitle for the limited-time offer. |
Link | field_lto_link | No | Add a link for the limited-time offer. |
Title | field_lto_title | Yes | Enter the title for the limited-time offer. |
5.30 - Location finder
This paragraph describes the Location finder paragraph type, which renders a block.
The Location finder block displays locations such as branches, camps, and facilities using a map and associated views. It may also include a filter block. For the Location finder block and Location finder filter block, see the
Open Y Map documentation.
Fields
Name | Machine name | Required | Description |
---|
Location finder | field_prgf_location_finder | No | Block reference to the location_finder block. It should have a default value and be hidden in the form display. This block renders the location map. |
5.31 - Location Finder Filters
This paragraph renders the Location Finder map with pins and filters. It allows users to filter locations displayed on the map based on tags or other criteria.
Fields
Name | Machine name | Required | Description |
---|
Location Finder | field_prgf_location_finder | No | Block reference to the location_finder block. This field should have a default value and be hidden in the form display to prevent direct user modification. |
Tags Style | field_prgf_lf_tags_style | Yes | Determines the style of tags used for the map tags filter. Options include: - Checkboxes (default) - Multiselect widget with checkboxes. |
5.32 - Membership Information Paragraph
This document describes the “Membership Information” paragraph type, which is used to display membership details such as location, link, fees, and rates. This paragraph is intended for use in the Membership content type.
Fields
Name | Machine name | Required | Description |
---|
Location | field_mbrshp_location | No | Select list with locations (branches). Single value. |
Link | field_mbrshp_link | No | Link field to provide the membership redirect URL. |
Join Fee | field_mbrshp_join_fee | No | Dollar value representing the one-time fee to join. |
Monthly Rate | field_mbrshp_monthly_rate | No | Dollar value representing the recurring monthly membership fee. |
5.33 - Microsites Menu
This paragraph type provides a microsites menu block.
Fields
Name | Machine name | Required | Description |
---|
Menu Block | field_prgf_block_ref | Yes | Block reference to the view/block. Create a new one or select an existing menu block. See the
Blocks documentation for more information. |
Hide Main Menu | field_prgf_ms_menu_hide_menu | No | Determines whether to hide the main website menu when this microsites menu is displayed. |
5.34 - News Posts Listing
This dynamic paragraph renders the latest news posts and utilizes exposed filters, allowing users to refine the displayed content.
The available filters are:
The News Posts Listing also features a “sticky at the top” option, ensuring important news remains visible. Items are ordered by published date, with the newest posts appearing first. This functionality relies on the Views module.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the View block. This should have a default value configured in the Paragraph type and hidden in the form display. |
5.35 - Program Registration (Daxko)
This paragraph renders the Programs Search Block.
The Programs Search Block provides a form to search programs from Daxko.
Related topics:
Daxko
Important: The Daxko and Program Registration (Daxko) configurations must be set up before the Program Registration paragraph will work.
Configuration settings are located at /admin/config/development/daxko/programs-search
. You must have the administer daxko
permission to configure these settings. See the
Daxko settings documentation for more information on configuring the connection to Daxko.
Fields
Name | Machine name | Required | Description |
---|
Program registration block | field_prgf_reg_block | No | Block reference to the programs_search_block block. Should have a default value and should be hidden in the form display. |
5.36 - Promo Card
The Promo Card is a Paragraph type used to create promotional content. It is often used in sidebars or other secondary areas of a page.
Fields
Name | Machine name | Required | Description |
---|
Title | field_prgf_title | No | Optional title for the Promo Card. Displayed above the Headline. |
Headline | field_prgf_headline | Yes | Headline of the Promo Card. Displayed below the Title. |
Description | field_prgf_description | No | A WYSIWYG field for the main content of the Promo Card. Does not support summaries. |
Link | field_prgf_link | No | A link field for internal and external links. Supports a call to action. |
5.37 - Schedule search form
This paragraph renders the session instance filters for the [Schedule search list](Schedule search list.md). It provides a dynamic form allowing users to filter session instances based on various criteria. The form is rendered using the SchedulesSearchFormBlock
plugin, which utilizes the SchedulesSearchForm
form.
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. This field stores a reference to a block, typically a view or another block, that provides the search form. It should have a default value and should be hidden in form display. The default value should be the schedules_search_form_block plugin. |
Usage
This paragraph is typically used in conjunction with the [Schedule search list](Schedule search list.md) paragraph to provide a filtering mechanism for session instances. It is rendered using the SchedulesSearchFormBlock
plugin.
Technical Details
- Plugin ID:
schedules_search_form_block
- Class:
Drupal\openy_schedules\Plugin\Block\SchedulesSearchFormBlock
- Form:
Drupal\openy_schedules\Form\SchedulesSearchForm
5.38 - Schedule search list
This dynamic paragraph renders the session instances based on URL parameters and/or filters from the [Schedule search form](Schedule search form.md).
Relates to [Branches Popup (All)](Branches Popup (All).md).
Fields
Name | Machine name | Required | Description |
---|
Block | field_prgf_block | Yes | Block reference to the view/block. Should have a default value and should be hidden in the form display. |
Use Cases
1.1 Preferred branch is selected and no location in URL
- When I open the Schedule search list page WITHOUT a location popup on the page
- And I have a preferred branch
- And I don’t have
location=%
in the URL - Then the filter by location should be predefined based on the cookie
- And the results should be filtered
1.2 Preferred branch is empty and no location in URL
- When I open the Schedule search list page WITHOUT a location popup on the page
- And I don’t have a preferred branch
- And I don’t have
location=%
in the URL - Then the filter by location should show “All”
- And the results should be shown for all branches
1.3 Location specified in URL
- When I open the Schedule search list page WITHOUT a location popup on the page
- And I have
location=%
in the URL - Then we skip the cookie, whether it is empty or exists
- And the filter by location should show the branch from the URL
- And the results should be filtered
2.1 Preferred branch is selected and no location in URL
- When I open the Schedule search list page WITH a location popup on the page
- And I have a preferred branch
- And I don’t have
location=%
in the URL - Then the location popup shouldn’t be shown
- And the filter by location should be predefined based on the cookie
- And the results should be filtered
2.2 Preferred branch is empty and no location in URL
- When I open the Schedule search list page WITH a location popup on the page
- And I don’t have a preferred branch
- And I don’t have
location=%
in the URL - Then the filter by location should show “All”
- And the results should be shown for all branches
- And the location popup should be shown
2.3 Location specified in URL
- When I open the Schedule search list page WITH a location popup on the page
- And I have
location=%
in the URL - Then we skip the cookie, whether it is empty or exists
- And the location popup shouldn’t be shown
- And the filter by location should show the branch from the URL
- And the results should be filtered
5.39 - Secondary Description and Sidebar
The Secondary Description and Sidebar paragraph type is designed for content layouts featuring a left column (secondary description) and a right column (sidebar). Both columns utilize blocks for flexible content placement.
Fields
Name | Machine Name | Required | Description |
---|
Left Column | field_prgf_left_column_block | No | A block reference field for the left column, often used for a secondary description. You can select from existing blocks or create a new one. Supported block types: Basic Block, Code Block, Date Block, or Simple Block. |
Right Column | field_prgf_right_column_block | No | A block reference field for the right column, typically used as a sidebar. You can select from existing blocks or create a new one. Supported block types: Basic Block, Code Block, Date Block, or Simple Block. |
Note: Blocks provide a modular way to organize and display content within the columns. Consider using Basic Blocks for standard text and media, Code Blocks for displaying code snippets, Date Blocks for event dates, and Simple Blocks for streamlined content elements. You can create these blocks in the “Blocks” section of the administrative interface. The “Block Content” module allows you to manage block types and content blocks. The block description is an identification name for a block, which is shown in the administrative interface and not displayed on the site. The block title is the heading that is optionally shown to site visitors when the block is placed in a region.
5.40 - Session Time
The Session Time paragraph is used within the Session content type to define the schedule for a session. It allows you to specify the date and time range, as well as the days of the week the session repeats.
Fields
Name | Machine name | Required | Description |
---|
Date & Time | field_session_time_date | No | This field uses the Datetime Range module to create a date/time field with start and end date/time options. This defines the period when the session is active. For example, January 1, 2024, to January 1, 2025. |
Days | field_session_time_days | No | Checkboxes to select the days of the week the session repeats. Available options: Sunday, Monday, Tuesday, Wednesday, Thursday, Friday, Saturday. If a date range and a day are selected, the session will occur on that day of the week within the specified date range. |
Session time override | field_session_time_override | No | Use this field to override the session time to text. |
5.41 - Simple Content
The Simple Content paragraph type is used for adding formatted text to pages. It provides a WYSIWYG editor for rich text input.
Fields
Name | Machine name | Required | Description |
---|
Content | field_prgf_description | Yes | WYSIWYG editor for formatted text content. |
5.42 - Small Banner
The Small Banner paragraph type is used to display banner content in a compact format.
Fields
Name | Machine name | Required | Description | Notes |
---|
Color | field_prgf_color | Yes | Reference field for choosing a color from the “Color” vocabulary. | Used for the banner’s background color. |
Headline | field_prgf_headline | Yes | Headline of the Small Banner. | Plain text, maximum 255 characters. |
Image | field_prgf_image | No | Entity reference to a media image. | Single value. Recommended image dimensions: [TBD]. |
Description | field_prgf_description | No | WYSIWYG field for the banner’s description, supports rich text formatting. | No summary option. Use sparingly to maintain a clean banner appearance. |
5.43 - Social Post Listing
This paragraph type renders the latest social posts imported from social networks and displays them in a masonry grid. It leverages a View block to select and format the posts.
Fields
Name | Machine name | Required | Description |
---|
Title | field_prgrf_sl_title | No | Title for the social posts block. This is a plain text field. |
Description | field_prgrf_sl_description | No | Description for the social posts block. This field supports longer text and can be used for introductory content. |
Social List | field_prgrf_sl_block | No | Reference to a View block. This block is configured to select social posts and display them. |
Details about the Social List (field_prgrf_sl_block) View Block:
- View:
social_posts_view
- Block Display:
social_posts_block
- This view selects nodes of the
social_post
content type. - The view provides an administrative interface at
admin/social-posts
to manage social posts. - The view displays the platform, ID, post content, and posted date for each social post.
5.44 - Social Share Icons
This paragraph type was used to add social media share icons, leveraging the AddThis service.
Important: The AddThis service has been deprecated as of May 31, 2023. This paragraph type no longer functions. See
Using AddToAny for its replacement.
See more
How to configure AddThis
Fields
Name | Machine name | Required | Description | Notes |
---|
Title | field_prgrf_sl_title | No | Block title. | You can add text here if your block needs a title. |
Description | field_prgrf_sl_description | No | Block Description. | You can add text here if your block needs a description. |
Block | field_prgrf_sl_block | Yes | | Select a social sharing plugin. |
5.45 - Story Card
The Story Card is a Paragraph type designed for use in sidebars, featuring a title, headline, and a link that turns the entire card into a call to action. This paragraph type is commonly used to highlight specific information or direct users to related content.
Fields
Name | Machine name | Required | Description |
---|
Title | field_prgf_title | No | Title of the Story Card. |
Headline | field_prgf_headline | Yes | Headline of the Story Card. A quotation mark will be displayed to the left of your headline in the Lily and Rose themes. |
Link | field_prgf_link | No | Link field that stores an internal or external URL. The entire card becomes the link, so use link text that encourages users to click. |
Usage Notes
Themes: The Story Card Paragraph renders with specific styling in the Lily and Rose themes, including a border. It may not have the same visual emphasis in other themes like Carnation.
Best Practices: To enhance usability, consider adding a >
or other special character to the link text to visually indicate it’s a clickable link.
Content Types: Story Cards are primarily designed for use in the sidebar region of content types, including:
- Landing Page
- News Post
- Blog Post
- Facility
- Program
- Program Subcategory
Advanced
5.46 - Teaser
The Teaser paragraph type is used to create visually engaging previews of content, often linking to more detailed information. It typically includes a title, image, short description, and a link.
Fields
Name | Machine name | Required | Description |
---|
Title | field_prgf_title | No | The title of the teaser. This is often displayed prominently. |
Image | field_prgf_image | No | A reference to a media image. This field accepts a single image to visually represent the teaser content. |
Description | field_prgf_description | No | A WYSIWYG field (What You See Is What You Get) allowing formatted text input for a brief description of the teaser content. A summary is not supported for this field. |
Link | field_prgf_link | No | A link field that stores internal and external URLs. This allows the teaser to link to other content within the site or external resources. |
Usage
Teaser paragraphs are commonly used on landing pages, content hubs, and in listing pages to promote specific articles, products, or sections of a website. They provide a concise overview and encourage users to explore further. The field_prgf_link
will take the user to the page that the Teaser is promoting.
Best Practices
- Image Dimensions: Use appropriately sized images to ensure optimal display and page load times.
- Concise Descriptions: Keep descriptions brief and focused on highlighting the key benefits or features of the linked content.
- Clear Call to Action: The link text should clearly indicate the destination and encourage user interaction (e.g., “Read More,” “Learn More,” “View Details”).
5.47 - Webform
This is a paragraph type used for embedding webforms within content. It allows you to add existing webforms to a page.
Prerequisites
- You must have already created your webform using the Webform module before embedding it. This paragraph type does not create a new webform.
- Consider reviewing the
Drupal Webform Tutorials (by Jacob Rockowitz) for comprehensive guidance on creating and managing webforms.
Add the Webform Paragraph: Select “Webform” from the available paragraph types when editing a content item.
Select the Webform: Choose the desired webform from the “Embedded Webform” field. This field displays a list of available webforms created using the Webform module.

Configure Webform Status: Use the “Webform status” field to control the webform’s availability:
- Open: Allows users to submit the webform.
- Closed: Prevents new submissions. Existing submissions remain accessible.
- Scheduled: Set open and close dates for the webform.
Default Webform Submission Data (Optional): The “Default webform submission data (YAML)” field allows you to pre-populate webform fields with default values.
- Enter YAML code to define the default values.
- This is useful for providing guidance or setting common values for users.
- Consult the
YAML specification for correct syntax.
Fields
Name | Machine name | Required | Description |
---|
Embedded Webform | field_prgf_webform | No | Webform entity reference field. Select the webform you want to embed. |
Default webform submission data (YAML) | field_prgf_webform_default_data | No | YAML code to pre-populate webform fields with default values. |
Webform status | field_prgf_webform_status | No | Controls the availability of the webform. Options: Open, Closed, or Scheduled. |
Content Types That Support Webform
6 - Taxonomy
6.1 - Amenities
This vocabulary is used to categorize branch amenities. It is used to tag Branch content.
Machine name: amenities
To manage the available amenities, navigate to:
admin/structure/taxonomy/manage/amenities/overview.
6.2 - Area
The Area vocabulary is used to categorize location areas on the site. This vocabulary is used by the Location Branch and Facility content types to classify the areas they serve. Areas can represent neighborhoods, regions, or any other relevant geographical or logical division.
Machine name: area
Details:
- This vocabulary is implemented as a taxonomy.
- Terms within this vocabulary are referenced by the
field_location_area
field on the Location Branch and Facility content types. - Consider using a hierarchical structure for your Area taxonomy to allow for more granular categorization (e.g., Continent > Country > Region > City > Neighborhood).
- When creating terms, ensure that the names are clear, concise, and representative of the area they describe. Use title case for term names (e.g., “Downtown”).
Related Content Types:
6.3 - Blog Category
This is a vocabulary that will be used for adding blog categories on the site. A vocabulary is a set of taxonomy terms. Taxonomy terms are used to classify website content.
Machine name: blog_category
Definition: A vocabulary for categorizing blog posts. Individual categories are known as terms.
See also:
6.4 - Color
This is a vocabulary used for adding colors. It is typically used as a reference field in other content types, such as Paragraphs.
Machine name: color
Fields
Name | Machine name | Required | Description |
---|
Name | drupal's default | Yes | Color name. |
Color | field_color | Yes | Color selector. This usually provides a color picker interface. |
6.5 - Facility Type
This is a vocabulary used for categorizing facilities on the site, specifically for the Facility content type.
Machine name: facility_type
6.6 - Media Tags
This vocabulary is used for adding media tags, which allow you to structure your media assets library. These tags are crucial for organizing, searching, and managing your media files effectively within the system.
Machine name: media_tags
Media tags, when applied correctly, enhance the discoverability and reusability of your media assets. They provide a controlled vocabulary for categorizing different types of media, such as images, videos, audio files, and documents. This categorization enables efficient filtering and sorting within the media library.
Consider the following benefits of using media tags:
- Improved Search: Users can quickly locate specific media assets by searching for relevant tags.
- Enhanced Organization: Media assets are neatly categorized, making it easier to browse and manage the library.
- Content Relationships: Tags can define relationships between different media items, showcasing related content.
- Workflow Automation: Automate media processing tasks based on assigned tags.
Best Practices
- Consistency: Use consistent tagging practices across all media assets.
- Specificity: Choose the most specific tags that accurately describe the media.
- Relevance: Ensure that tags are relevant to the content of the media asset.
- Hierarchy: When creating tags, it’s important to have a hierarchy so that filtering and searching can find all of the related tags.
By implementing a well-defined media tagging strategy, you can significantly improve the usability and effectiveness of your media asset library.
6.7 - News Category
This vocabulary is used for categorizing news articles on the site. Taxonomy terms are grouped into vocabularies. This vocabulary provides a predefined set of categories for news content, ensuring consistency and facilitating content organization and filtering.
Machine Name: news_category
Description:
- Used to classify news content.
- Terms within this vocabulary can be used to create lists of related articles, filter news feeds, and improve site navigation.
- Allows content editors to assign one or more categories to each news item.
Usage:
- The
news_category
vocabulary is used with a “Taxonomy term” reference field attached to the “News” content type. - When creating or editing a news article, users can select relevant categories from the available terms in this vocabulary.
See Also: