This is the multi-page printable view of this section. Click here to print.

Return to the regular view of this page.

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:

  1. Install the Paragraphs module.
  2. Create Paragraphs types.
  3. Add a Paragraph field to a content type.
  4. Begin creating content and adding paragraphs.

1 - 1 Column

The 1 Column paragraph type allows you to create a single-column layout within your content.

Fields

NameMachine nameRequiredDescriptionNotes
Line Abovefield_prfg_display_line_aboveNoDisplay a line above the column.
Columnfield_prgf_1c_columnNoEnter the main content for the single column. This field typically supports rich text.
Paragraph Titlefield_prgf_1c_titleNoEnter a title to display at the top of the 1-column paragraph.
Paragraph Descriptionfield_prgf_1c_descriptionNoEnter a description to display below the paragraph title.

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

NameMachine nameRequiredDescriptionNotes
Line Abovefield_prfg_display_line_aboveNoDisplay a horizontal line above the columns.
Left Columnfield_prgf_2c_leftNoContent for the left column.Supports text, images, and other embedded content.
Right Columnfield_prgf_2c_rightNoContent for the right column.Supports text, images, and other embedded content.

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

NameMachine nameRequiredDescriptionNotes
Line Abovefield_prfg_display_line_aboveNoDisplay a line above the column.
Left Columnfield_prgf_3c_leftNoEnter the content for the left column.
Center Columnfield_prgf_3c_centerNoEnter the content for the center column.
Right Columnfield_prgf_3c_rightNoEnter the content for the right column.
Paragraph Titlefield_prgf_titleNoEnter a title to display at the top of the 3 columns paragraph.

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

NameMachine nameRequiredDescriptionNotes
Line Abovefield_prfg_display_line_aboveNoDisplay a line above the column.Use this to visually separate this paragraph from the content above it.
First Columnfield_prgf_4c_1stNoEnter the content for the first column.Supports text, images, and other embedded content.
Second Columnfield_prgf_4c_2ndNoEnter the content for the second column.Supports text, images, and other embedded content.
Third Columnfield_prgf_4c_3rdNoEnter the content for the third column.Supports text, images, and other embedded content.
Fourth Columnfield_prgf_4c_4thNoEnter the content for the fourth column.Supports text, images, and other embedded content.
Buttonfield_prgf_4c_buttonNoButton 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 Titlefield_prgf_titleNoEnter a title to display at the top of the 4-column paragraph.This provides a clear heading for the entire paragraph.
Paragraph Descriptionfield_prgf_descriptionNoEnter 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 - All Amenities

This paragraph displays a list of amenities, typically in a table view. It’s useful for showcasing available features or services.

Fields

NameMachine nameRequiredDescription
All amenitiesfield_field_prgf_amnts_viewNoPredefined reference to a view that displays all amenities. Configure this view to control which amenities are shown and how they are formatted.
Titlefield_prgf_titleNoEnter 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.

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

NameMachine nameRequiredDescriptionNotes
Headlinefield_prgf_headlineYesThe main heading of the banner. This should be concise and attention-grabbing.Plain text, maximum 255 characters
Colorfield_prgf_colorYesA 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
Imagefield_prgf_imageNoAn entity reference to a media image. This image should be visually appealing and relevant to the banner’s content.Single value
Descriptionfield_prgf_descriptionNoA 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.
Linkfield_prgf_linkNoA 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

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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:

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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.

Class Page WITHOUT Location Popup

Use case 3: Class page WITHOUT location popup

Location Specified in URL
  1. 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
  1. 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.

Class Page WITH Location Popup

Use case 4: Class page WITH location popup

Location Specified in URL
  1. 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
  1. 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock reference to the view/block. A default value should be set, and this field should be hidden in the form display.

Use Cases

Use case 1: Classes Listing paragraph on a Program subcategory page WITHOUT location popup paragraph

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.

Use case 2: Classes Listing paragraph on a Program subcategory page WITH location popup

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.

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

NameMachine nameRequiredDescription
Codefield_prgf_code_blockYesBlock 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.

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

NameMachine NameRequiredDescription
Headlinefield_prgf_headlineNoHeadline of the banner. This is a simple text field.
Blog Postsfield_fblog_postsYesMultiple values. A reference field that links to Blog posts. The blog posts are sourced from nodes of the “Blog” content type.

Module Information

  • 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

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

NameMachine nameRequiredDescription
Headlinefield_prgf_headlineNoHeadline of the featured content.
Descriptionfield_prgf_descriptionNoText area for the description/body with WYSIWYG, without summary.
Linkfield_prgf_linkNoLink field that supports internal and external URLs.
Stylefield_prgf_grid_styleYesSelect list defining the number of items per row: 2: 2 items, 3: 3 items, 4: 4 items.
Column descriptionfield_prgf_fc_clm_descriptionNoMultiple values. Text area for column descriptions with WYSIWYG, without summary.

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

NameMachine nameRequiredDescription
Titlefield_prgf_titleNoOptional paragraph title displayed above the grid of blocks.
Stylefield_prgf_grid_styleYesDetermines 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 blockfield_prgf_block_ref_unlimYesReferences 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.

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

NameMachine nameRequiredDescription
Headlinefield_prgf_headlineNoHeadline for the featured news section. This will appear above the linked news posts.
News Postsfield_fnews_postsYesMultiple values. References existing News posts (nodes of type “News”). The referenced news posts will be displayed in this section.

Usage

  1. When creating or editing a page or content type that supports paragraphs, select the “Featured News Posts” paragraph type.
  2. Enter a “Headline” for the section (optional).
  3. In the “News Posts” field, select one or more existing News posts. Use the autocomplete functionality to search for news posts by title.
  4. 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.

19 - Gallery

The Gallery paragraph type is used to display a collection of images, often with accompanying text and links.

Fields

NameMachine NameRequiredDescription
Headlinefield_prgf_headlineYesHeadline of the gallery. Plain text.
Descriptionfield_prgf_descriptionNoWYSIWYG field without summary. Allows for rich text formatting to describe the gallery.
Linkfield_prgf_linkNoLink field for internal and external URLs. Can be used to link to more information.
Imagesfield_prgf_imagesNoEntity reference to media images. Supports multiple images in the gallery.

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

NameMachine nameRequiredDescription
Descriptionfield_prgf_grid_clm_descriptionNoTextarea for the column’s description or body content. Supports WYSIWYG editing, but does not include a summary field.
Headlinefield_prgf_clm_headlineNoHeadline for the grid content within the column.
Iconfield_prgf_clm_iconNoEntity reference to a media asset, typically an image. Recommended to allow uploading of SVGs for scalability.
Icon classfield_prgf_clm_classNoInput field for adding Font Awesome icon classes (e.g., flag, car, info). Overrides the image specified in the Icon field.
Linkfield_prgf_clm_linkNoLink field that supports both internal and external URLs.

21 - Grid Content

The Grid Content paragraph type is used to create grid layouts within stories.

Fields

NameMachine nameRequiredDescription
Stylefield_prgf_grid_styleYesSelect 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.
Contentfield_grid_columnsParagraphGrid columns. This field references the Grid columns paragraph type, allowing you to add individual columns to the grid.
Descriptionfield_prgf_grid_clm_descriptionNoTextarea for the column description/body. Supports WYSIWYG editing, but without a summary option.
Headlinefield_prgf_clm_headlineNoHeadline for the grid content column.
Iconfield_prgf_clm_iconNoEntity reference to a media asset, typically an SVG image. Allows uploading of new SVG files.
Icon classfield_prgf_clm_classNoInput field for adding Font Awesome icon classes (e.g., flag, car, info). This will override the image Icon.
Linkfield_prgf_clm_linkNoLink field that supports both internal and external URLs.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock reference to the view/block that displays the GroupEx Pro schedule. A default value should be set and is configurable in the form display.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesThis 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock reference to the view/block. This field should have a default value and is typically hidden in the form display.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesA 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesThis 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.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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.

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

NameMachine nameRequiredDescription
Subtitlefield_lto_subtitleNoEnter the subtitle for the limited-time offer.
Linkfield_lto_linkNoAdd a link for the limited-time offer.
Titlefield_lto_titleYesEnter the title for the limited-time offer.

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

NameMachine nameRequiredDescription
Location finderfield_prgf_location_finderNoBlock 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.

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

NameMachine nameRequiredDescription
Location Finderfield_prgf_location_finderNoBlock 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 Stylefield_prgf_lf_tags_styleYesDetermines the style of tags used for the map tags filter. Options include:
- Checkboxes (default)
- Multiselect widget with checkboxes.

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

NameMachine nameRequiredDescription
Locationfield_mbrshp_locationNoSelect list with locations (branches). Single value.
Linkfield_mbrshp_linkNoLink field to provide the membership redirect URL.
Join Feefield_mbrshp_join_feeNoDollar value representing the one-time fee to join.
Monthly Ratefield_mbrshp_monthly_rateNoDollar value representing the recurring monthly membership fee.

33 - Microsites Menu

This paragraph type provides a microsites menu block.

Fields

NameMachine nameRequiredDescription
Menu Blockfield_prgf_block_refYesBlock reference to the view/block. Create a new one or select an existing menu block. See the Blocks documentation for more information.
Hide Main Menufield_prgf_ms_menu_hide_menuNoDetermines whether to hide the main website menu when this microsites menu is displayed.

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:

  • Location
  • Category
  • Text

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock reference to the View block. This should have a default value configured in the Paragraph type and hidden in the form display.

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

NameMachine nameRequiredDescription
Program registration blockfield_prgf_reg_blockNoBlock reference to the programs_search_block block. Should have a default value and should be hidden in the form display.

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

NameMachine nameRequiredDescription
Titlefield_prgf_titleNoOptional title for the Promo Card. Displayed above the Headline.
Headlinefield_prgf_headlineYesHeadline of the Promo Card. Displayed below the Title.
Descriptionfield_prgf_descriptionNoA WYSIWYG field for the main content of the Promo Card. Does not support summaries.
Linkfield_prgf_linkNoA link field for internal and external links. Supports a call to action.

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock 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

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

NameMachine nameRequiredDescription
Blockfield_prgf_blockYesBlock reference to the view/block. Should have a default value and should be hidden in the form display.

Use Cases

Use Case 1: Schedule search list paragraph on a page WITHOUT a location popup paragraph

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

Use Case 2: Schedule search list paragraph on a page WITH a location popup

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

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

NameMachine NameRequiredDescription
Left Columnfield_prgf_left_column_blockNoA 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 Columnfield_prgf_right_column_blockNoA 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.

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

NameMachine nameRequiredDescription
Date & Timefield_session_time_dateNoThis 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.
Daysfield_session_time_daysNoCheckboxes 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 overridefield_session_time_overrideNoUse this field to override the session time to text.

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

NameMachine nameRequiredDescription
Contentfield_prgf_descriptionYesWYSIWYG editor for formatted text content.

42 - Small Banner

The Small Banner paragraph type is used to display banner content in a compact format.

Fields

NameMachine nameRequiredDescriptionNotes
Colorfield_prgf_colorYesReference field for choosing a color from the “Color” vocabulary.Used for the banner’s background color.
Headlinefield_prgf_headlineYesHeadline of the Small Banner.Plain text, maximum 255 characters.
Imagefield_prgf_imageNoEntity reference to a media image.Single value. Recommended image dimensions: [TBD].
Descriptionfield_prgf_descriptionNoWYSIWYG field for the banner’s description, supports rich text formatting.No summary option. Use sparingly to maintain a clean banner appearance.

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

NameMachine nameRequiredDescription
Titlefield_prgrf_sl_titleNoTitle for the social posts block. This is a plain text field.
Descriptionfield_prgrf_sl_descriptionNoDescription for the social posts block. This field supports longer text and can be used for introductory content.
Social Listfield_prgrf_sl_blockNoReference 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.

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

NameMachine nameRequiredDescriptionNotes
Titlefield_prgrf_sl_titleNoBlock title.You can add text here if your block needs a title.
Descriptionfield_prgrf_sl_descriptionNoBlock Description.You can add text here if your block needs a description.
Blockfield_prgrf_sl_blockYesSelect a social sharing plugin.

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

NameMachine nameRequiredDescription
Titlefield_prgf_titleNoTitle of the Story Card.
Headlinefield_prgf_headlineYesHeadline of the Story Card. A quotation mark will be displayed to the left of your headline in the Lily and Rose themes.
Linkfield_prgf_linkNoLink 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

  • Custom CSS: To disable the quotation mark in the headline area (Lily and Rose), use the following CSS:

    .story-card .quote svg {
      display: none;
    }
    

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

NameMachine nameRequiredDescription
Titlefield_prgf_titleNoThe title of the teaser. This is often displayed prominently.
Imagefield_prgf_imageNoA reference to a media image. This field accepts a single image to visually represent the teaser content.
Descriptionfield_prgf_descriptionNoA 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.
Linkfield_prgf_linkNoA 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”).

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.

How to Use the Webform Paragraph

  1. Add the Webform Paragraph: Select “Webform” from the available paragraph types when editing a content item.

  2. 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.

    Webform paragraph admin fields

  3. 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.
  4. 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

NameMachine nameRequiredDescription
Embedded Webformfield_prgf_webformNoWebform entity reference field. Select the webform you want to embed.
Default webform submission data (YAML)field_prgf_webform_default_dataNoYAML code to pre-populate webform fields with default values.
Webform statusfield_prgf_webform_statusNoControls the availability of the webform. Options: Open, Closed, or Scheduled.

Content Types That Support Webform