diff --git a/templates/content/node--uw-ct-single-page-home.html.twig b/templates/content/node--uw-ct-single-page-home.html.twig new file mode 100644 index 0000000000000000000000000000000000000000..e5a0fb3eacc3faa92550fabdbc6dd901521bde0a --- /dev/null +++ b/templates/content/node--uw-ct-single-page-home.html.twig @@ -0,0 +1,73 @@ +{# +/** + * @file + * Theme override to display a node. + * + * Available variables: + * - node: The node entity with limited access to object properties and methods. + * Only method names starting with "get", "has", or "is" and a few common + * methods such as "id", "label", and "bundle" are available. For example: + * - node.getCreatedTime() will return the node creation timestamp. + * - node.hasField('field_example') returns TRUE if the node bundle includes + * field_example. (This does not indicate the presence of a value in this + * field.) + * - node.isPublished() will return whether the node is published or not. + * Calling other methods, such as node.delete(), will result in an exception. + * See \Drupal\node\Entity\Node for a full list of public properties and + * methods for the node object. + * - label: The title of the node. + * - content: All node items. Use {{ content }} to print them all, + * or print a subset such as {{ content.field_example }}. Use + * {{ content|without('field_example') }} to temporarily suppress the printing + * of a given child element. + * - author_picture: The node author user entity, rendered using the "compact" + * view mode. + * - metadata: Metadata for this node. + * - date: Themed creation date field. + * - author_name: Themed author name field. + * - url: Direct URL of the current node. + * - display_submitted: Whether submission information should be displayed. + * - attributes: HTML attributes for the containing element. + * The attributes.class element may contain one or more of the following + * classes: + * - node: The current template type (also known as a "theming hook"). + * - node--type-[type]: The current node type. For example, if the node is an + * "Article" it would result in "node--type-article". Note that the machine + * name will often be in a short form of the human readable label. + * - node--view-mode-[view_mode]: The View Mode of the node; for example, a + * teaser would result in: "node--view-mode-teaser", and + * full: "node--view-mode-full". + * The following are controlled through the node publishing options. + * - node--promoted: Appears on nodes promoted to the front page. + * - node--sticky: Appears on nodes ordered above other non-sticky nodes in + * teaser listings. + * - node--unpublished: Appears on unpublished nodes visible only to site + * admins. + * - title_attributes: Same as attributes, except applied to the main title + * tag that appears in the template. + * - content_attributes: Same as attributes, except applied to the main + * content tag that appears in the template. + * - author_attributes: Same as attributes, except applied to the author of + * the node tag that appears in the template. + * - title_prefix: Additional output populated by modules, intended to be + * displayed in front of the main title tag that appears in the template. + * - title_suffix: Additional output populated by modules, intended to be + * displayed after the main title tag that appears in the template. + * - view_mode: View mode; for example, "teaser" or "full". + * - teaser: Flag for the teaser state. Will be true if view_mode is 'teaser'. + * - page: Flag for the full page state. Will be true if view_mode is 'full'. + * - readmore: Flag for more state. Will be true if the teaser content of the + * node cannot hold the main body content. + * - logged_in: Flag for authenticated user status. Will be true when the + * current user is a logged-in member. + * - is_admin: Flag for admin user status. Will be true when the current user + * is an administrator. + * + * @see template_preprocess_node() + * + * @todo Remove the id attribute (or make it a class), because if that gets + * rendered twice on a page this is invalid CSS for example: two lists + * in different view modes. + */ +#} +{% include "@organisms/_node.twig" %} diff --git a/templates/paragraphs/paragraph--sph-para-header-video.html.twig b/templates/paragraphs/paragraph--sph-para-header-video.html.twig new file mode 100644 index 0000000000000000000000000000000000000000..b5473a894e65df8df7b2ec7a483e5deefb0d4a28 --- /dev/null +++ b/templates/paragraphs/paragraph--sph-para-header-video.html.twig @@ -0,0 +1,47 @@ +{# +/** + * @file + * Default theme implementation to display a paragraph. + * + * Available variables: + * - paragraph: Full paragraph entity. + * - id: The paragraph ID. + * - bundle: The type of the paragraph, for example, "image" or "text". + * - authorid: The user ID of the paragraph author. + * - createdtime: Formatted creation date. Preprocess functions can + * reformat it by calling format_date() with the desired parameters on + * $variables['paragraph']->getCreatedTime(). + * - content: All paragraph items. Use {{ content }} to print them all, + * or print a subset such as {{ content.field_example }}. Use + * {{ content|without('field_example') }} to temporarily suppress the printing + * of a given child element. + * - sources: The attributes of the <source> tags for this <picture> tag. + * - img_element: The controlling image, with the fallback image in srcset. + * - output_image_tag: Whether or not to output an <img> tag instead of a + * <picture> tag. + * - attributes: HTML attributes for the containing element. + * The attributes.class element may contain one or more of the following + * classes: + * - paragraphs: The current template type (also known as a "theming hook"). + * - paragraphs--type-[type]: The current paragraphs type. For example, if the paragraph is an + * "Image" it would result in "paragraphs--type--image". Note that the machine + * name will often be in a short form of the human readable label. + * - paragraphs--view-mode--[view_mode]: The View Mode of the paragraph; for example, a + * preview would result in: "paragraphs--view-mode--preview", and + * default: "paragraphs--view-mode--default". + * - view_mode: View mode; for example, "preview" or "full". + * - logged_in: Flag for authenticated user status. Will be true when the + * current user is a logged-in member. + * - is_admin: Flag for admin user status. Will be true when the current user + * is an administrator. + * + * @see template_preprocess_paragraph() + * + * @ingroup themeable + */ +#} +{{ attach_library('uw_fdsu_theme_resp/header_video') }} +{% include "@organisms/single-page/header-video/header-video.twig" with { + "video_url": content.field_sph_banner_video|field_value, + "description": content.field_sph_banner_description|field_value +} %} diff --git a/uw_fdsu_theme_resp.libraries.yml b/uw_fdsu_theme_resp.libraries.yml index 9edaec10bb51d95936fc20eb05a256853cb852bd..ba2dd4af68a7b49b7485d0a62384b01f50aa8f8c 100644 --- a/uw_fdsu_theme_resp.libraries.yml +++ b/uw_fdsu_theme_resp.libraries.yml @@ -13,6 +13,10 @@ responsive_menu_combined: js: uw_wcms_pattern_lab/components/_patterns/02-molecules/menus/responsive-menu-combined/responsive-menu-combined.js: {} +header_video: + js: + uw_wcms_pattern_lab/components/_patterns/03-organisms/single-page/header-video/header-video.js: {} + main_menu: js: uw_wcms_pattern_lab/components/_patterns/02-molecules/menus/main-menu/main-menu.js: {} diff --git a/uw_fdsu_theme_resp.theme b/uw_fdsu_theme_resp.theme index 3ecc51695116b1aedfc7fe823055e94119cd614d..3255887bcc14e944f3966728674603a6037dae80 100644 --- a/uw_fdsu_theme_resp.theme +++ b/uw_fdsu_theme_resp.theme @@ -26,6 +26,22 @@ function uw_fdsu_theme_resp_preprocess_region(&$variables) { } } +function uw_fdsu_theme_resp_preprocess_node(&$variables) { + + switch ($variables['node']->getType()) { + case "uw_ct_single_page_home": + $image_or_video = $variables['node']->get('field_sph_image_or_video')->value; + + if ($image_or_video == "Video") { + unset($variables['content']['field_uw_sph_header_image']); + } + else { + unset($variables['content']['field_uw_banner_video']); + } + break; + } +} + /** * Implements hook_preprocess_paragraph(). *