<section class="homepage_hero left">
    <div class="hero_text">
        <h1>This is Page Heading</h1>
        <p>
        <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam.</p>
        </p>
        <div class="hero-buttons">
            <a href="#" class="btn btn-primary dark-grey" role="button">
                <span class="button_text">Action Button</span>
                <span class="arrow fal fa-chevron-right"></span>
            </a>
        </div><!-- end hero-buttons -->
    </div><!-- end hero_text -->
    <div class="hero_video">
        <div id="video-section-wrapper">
            <div id="video">
                <video id="bgvid" autoplay loop muted playsinline>
                    <source src="/video/Gliding_Shot_2.mp4" type="video/mp4">
                    <img src="/img/video-fallback.jpg" />
                </video>
                <div class="video-controls">
                    <button id="pause-btn" aria-pressed="false">
                        <i class="fa fa-play"></i>
                        <i class="fa fa-pause"></i>
                        <span class="sr-only">Pause Video</span>
                    </button>
                </div>
                <div class="mobile-background"></div>
            </div>
        </div> <!-- video-section-wrapper -->
    </div><!-- end hero_img -->
</section>
<section class="homepage_hero {{ align_text }}">
  <div class="hero_text">
    <h1>{{ hero_heading }}</h1>
    <p>{{ hero_text }}</p>
    <div class="hero-buttons">
      {% for button in buttons %}
        {% include "@a_tag" with button only %}
      {% endfor %}
      </div><!-- end hero-buttons -->
  </div><!-- end hero_text -->
  <div class="hero_video">
    <div id="video-section-wrapper">
      <div id="video">
        <video id="bgvid" autoplay loop muted playsinline>
          <source src="{{ hero_video_src }}" type="video/mp4">
          <img src="{{ hero_video_fallback }}" />
        </video>
        <div class="video-controls">
          <button id="pause-btn" aria-pressed="false">
            <i class="fa fa-play"></i>
            <i class="fa fa-pause"></i>
            <span class="sr-only">Pause Video</span>
          </button>
        </div>
        <div class="mobile-background"></div>
      </div>
    </div> <!-- video-section-wrapper -->
  </div><!-- end hero_img -->
</section>
{
  "hero_video_src": "/video/Gliding_Shot_2.mp4",
  "hero_video_fallback": "/img/video-fallback.jpg",
  "hero_heading": "This is Page Heading",
  "hero_text": "<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam.</p>",
  "align_text": "left",
  "buttons": {
    "1": {
      "text": "Action Button",
      "url": "#",
      "color": "dark-grey"
    }
  }
}
  • Content:
    (function (Drupal) {
      Drupal.behaviors.video_autoplay = {
        attach: function (context) {
          var videos = document.querySelectorAll("video");
          var videosPauseButton = document.querySelector("#pause-btn");
          var localStorageKey = 'eng2017.noAutoplayVideo';
    
          function videosShouldAutoplay() {
            return (!window.matchMedia('(prefers-reduced-motion: reduce)').matches &&
              window.localStorage.getItem(localStorageKey) != 'true');
          }
    
          function videosPaused() {
            return videosPauseButton.getAttribute("aria-pressed") === 'true';
          }
    
          function toggleButton(state) {
            var state = state || !videosPaused();
            videosPauseButton.setAttribute("aria-pressed", state);
          }
    
          function handleClick() {
            if (videosPaused()) {
              playVideos();
            }
            else {
              pauseAllVideos();
            }
    
            toggleButton();
          }
    
          function pauseAllVideos() {
            videos.forEach(function (video) {
              video.classList.add("is-paused");
              video.pause();
            });
    
            window.localStorage.setItem(localStorageKey, true);
          }
    
          function playVideos() {
            document.querySelectorAll("video.is-paused:not([controls])").forEach(function (video) {
              video.classList.remove("is-paused");
              video.play();
            });
    
            window.localStorage.setItem(localStorageKey, false);
          }
    
          function init() {
            if (!videosShouldAutoplay()) {
              videos.forEach(function (video) {
                if (video.hasAttribute("autoplay")) {
                  video.addEventListener("canplay", function () {
                    if (!video.hasAttribute("poster")) {
                      this.currentTime = 1;
                    }
    
                    this.pause();
                    video.classList.add("is-paused");
                  });
                }
              });
    
              toggleButton(false);
              pauseAllVideos();
            }
          }
    
          init();
          videosPauseButton.addEventListener("click", handleClick);
        }
      }
    })(Drupal);
    
  • URL: /components/raw/hero_homepage_video/hero_homepage_video.js
  • Filesystem Path: bits/04-components/heros/hero_homepage_video/hero_homepage_video.js
  • Size: 2.1 KB
  • Content:
    .homepage_hero {
      .hero_video {
        order: 1;
        width: 100%;
    
        @include media-breakpoint-up(lg) {
          width: 50%;
        }
    
        .mobile-background {
          position: absolute;
          top: 0;
          left: 0;
          height: 100%;
          width: 100%;
          background-size: cover;
          background-position: center center;
          display: block;
        }
    
        #video {
          position: relative;
          color: #fff;
          background-color: #000;
          background-size: cover;
          background-position: center center;
          background-image: url('../img/video-fallback.jpg');
          padding-bottom: 56.25%;
    
          video {
            position: absolute;
            width: 100%;
            max-width: 100%;
            top: 0;
            left: 0;
            height: 100%;
    
            .not-front & {
              display: none;
            }
          }
    
          .video-controls {
            position: absolute;
            top: 25px;
            right: 25px;
            z-index: 99;
    
            button {
              cursor: pointer;
              background-color: unset;
              border: 0;
    
              &:hover,
              &:focus {
                .fa {
                  opacity: 1;
                }
              }
    
              .fa {
                color: #fff;
                font-size: 36px;
                opacity: .8;
              }
    
              &[aria-pressed="false"] {
                .fa-play {
                  display: none;
                }
              }
    
              &[aria-pressed="true"] {
                .fa-pause {
                  display: none;
                }
              }
            }
          }
        }
    
        .html5-video-player {
          background-color: #1b75bc !important;
        }
      }
    
      &.Left {
        .hero_text {
          border-top: 3px solid $accent_color;
          border-top: 3px solid var(--accent_color, $accent_color);
    
          @include media-breakpoint-up(lg) {
            order: 1;
            border-top: 0;
            border-right: 3px solid $accent_color;
            border-right: 3px solid var(--accent_color, $accent_color);
          }
        }
    
        .hero_video {
          @include media-breakpoint-up(lg) {
            order: 1;
          }
        }
      }
    
      &.Right {
        .hero_text {
          border-top: 3px solid $accent_color;
          border-top: 3px solid var(--accent_color, $accent_color);
    
          @include media-breakpoint-up(lg) {
            order: 2;
            border-top: 0;
            border-left: 3px solid $accent_color;
            border-left: 3px solid var(--accent_color, $accent_color);
          }
        }
    
        .hero_video {
          @include media-breakpoint-up(lg) {
            order: 1;
          }
        }
      }
    
      &.full {
        position: relative;
    
        .hero_text {
          background-color: var(--white, $white);
          max-width: 40%;
          position: absolute;
          top: 3%;
    
          @include media-breakpoint-down(md) {
            position: relative;
            max-width: unset;
            width: 100%;
          }
        }
    
        .hero_video {
          width: 100%;
        }
    
        &.left {
          .hero_text {
            left: 3%;
    
            @include media-breakpoint-down(md) {
              left: unset;
            }
          }
    
          .hero_video {
            #video {
              .video-controls {
                left: unset;
                right: 25px;
              }
            }
          }
        }
    
        &.right {
          .hero_text {
            right: 3%;
    
            @include media-breakpoint-down(md) {
              right: unset;
            }
          }
    
          .hero_video {
            #video {
              .video-controls {
                left: 25px;
              }
            }
          }
        }
      }
    
    }
    
  • URL: /components/raw/hero_homepage_video/hero_homepage_video.scss
  • Filesystem Path: bits/04-components/heros/hero_homepage_video/hero_homepage_video.scss
  • Size: 3.4 KB

Display homepage hero where the video is 50% of the width along with the content. On a mobile display it becomes a stacked component.