Skip to content
Snippets Groups Projects
navbar.html 12.04 KiB
{% load static wagtailimages_tags wagtailcore_tags %}

{% if page.root_page.light_logo %}
  {% image page.root_page.light_logo max-256x256 as light_logo %}
{% endif %}

{% if page.root_page.dark_logo %}
  {% image page.root_page.dark_logo max-256x256 as dark_logo %}
{% endif %}

<!-- Navbar -->
<nav
  id="navbar"
  class="
    fixed left-0 top-[-1px] z-20 w-full duration-200 navbar

    {% if is_transparent and page.root_page.has_expanded_navbar %}
      xl:sticky sticky
    {% else %}
      xl:absolute
    {% endif %}

    {% block extra_classes %}
      {% if is_transparent %}navbar--transparent{% endif %}
      {% if is_on_dark_background %}navbar--on-dark-bg{% endif %}
    {% endblock %}
  "
>
  <div
    class="
      __navbar-inner container--wide py-3 xl:py-6 flex justify-between items-center
    "
  >
    <div class="flex items-center xl:items-start">
      {% if page.root_page.show_logo is not False %}
        <!-- BEGIN Logo-->
        <a
          href="{{ page.root_page.url }}"
          class="__navbar-logo-wrapper z-20 xl:mt-2 hover:no-underline"
        >
          {% block navbar_logo_images %}
            <img
              class="navbar__logo--white w-[150px] lg:w-[180px]"
              src="{% if light_logo %}{{ light_logo.url }}{% else %}{% static 'styleguide2/images/logo-full-white.svg' %}{% endif %}"
              alt="{% if light_logo %}{{ light_logo.alt }}{% else %}Pirátské logo{% endif %}"
            >
            <img
              class="navbar__logo--black w-[150px] lg:w-[180px]"
              src="{% if dark_logo %}{{ dark_logo.url }}{% else %}{% static 'styleguide2/images/logo-full-black.svg' %}{% endif %}"
              alt="{% if dark_logo %}{{ dark_logo.alt }}{% else %}Pirátské logo{% endif %}"
            >
          {% endblock %}
        </a>
        <!-- END Logo -->
      {% endif %}
    </div>

    <div class="flex-col gap-3 xl:flex hidden">

      <!-- BEGIN Social media-->
      <div class="__navbar-social-media flex gap-7 justify-end items-center">
        <div class="flex gap-5 text-lg">
          {% for social_link_block in page.root_page.social_links %}
            <a href="{{ social_link_block.value.link }}" class="hover:no-underline">
              <i class="{{ social_link_block.value.icon }}"></i>
            </a>
          {% endfor %}
        </div>

        {% if page.root_page.search_page %}
          <form method="GET" action="{{ page.root_page.search_page.url }}">
            {% include 'styleguide2/includes/atoms/form_fields/form_input.html' with placeholder='Hledej' classes='text-black p-3 w-60' name='q' value=global_search_query %}
          </form>
        {% endif %}

        {% block after_desktop_search %}{% endblock %}
      </div>
      <!-- END Social media -->

      <!-- BEGIN Menu -->
      <div
        class="__navbar-menu flex text-2xl gap-4 font-alt items-center justify-end"
      >
        {% if page.root_page.important_item_name %}
          {% firstof page.root_page.important_item_page.url page.root_page.important_item_url as target %}

          <a
            href="{{ target }}"
            class="
              __js-root mx-2 flex gap-1 items-center decoration-1 underline-offset-4

              navbar__menu-item

              {% if selected_item == page.root_page.important_item_name %}navbar__menu-item--selected{% endif %}
            "
          >
            <div class="mb-1">
              {% if not is_transparent %}
                {% include 'styleguide2/includes/atoms/icons/arrow.html' with width='27' height='28.35' fill='#fff' %}
              {% else %}
                <ui-animated-arrow
                  mobile-width="38.1"
                  mobile-height="40"

                  desktop-width="27"
                  desktop-height="28.35"
                ></ui-animated-arrow>
              {% endif %}
            </div>

            <span>
              {{ page.root_page.important_item_name }}
            </span>
          </a>
        {% endif %}

        {% for menu_item in page.root_page.menu %}
          {% if menu_item.block_type == "menu_item" %}
            {% firstof menu_item.value.page.url menu_item.value.link as target %}

            <a
              href="{{ target }}"
              class="
                mx-2 decoration-1 underline-offset-4

                navbar__menu-item

                {% if menu_item.value.title == selected_item %}navbar__menu-item--selected{% endif %}
              "
            >{{ menu_item.value.title }}</a>
          {% else %}
            {% include_block menu_item %}
          {% endif %}
        {% endfor %}

        {% if page.root_page.menu_button_content or page.root_page.popout_button_content %}
          {% block navbar_menu_button %}
            <div
              class="group uppercase cursor-pointer relative"
            >
              <div class="w-24 h-11 min-w-[9rem]">
                <div
                  class="
                    navbar__border-button

                    flex items-center justify-center border-none border-4 w-24 h-11 py-4 px-6 duration-150

                    xl:w-auto
                  "
                >{% if page.root_page.menu_button_name %}{{ page.root_page.menu_button_name }}{% else %}Zapoj se{% endif %}</div>
              </div>

              <div
                class="
                  absolute w-full top-[2.75rem] left-0 opacity-0 duration-150 pointer-events-none

                  group group-hover:opacity-100 group-hover:pointer-events-auto
                "
              >
                {% for button in page.root_page.menu_button_content %}
                  {% include_block button %}
                {% endfor %}
              </div>
            </div>
          {% endblock %}
        {% endif %}
      </div>
      <!-- END Menu -->

    </div>

    <!-- Hamburger Icon -->
    <input class="hidden navbar__mobile-menu__toggle" type="checkbox" id="navbar__mobile-menu__toggle">

    <label class="z-30 hamb text-black xl:hidden" for="navbar__mobile-menu__toggle">
      <span>
        <span class="bar1"></span>
        <span class="bar2"></span>
        <span class="bar3"></span>
      </span>
    </label>

    <div
      class="
        navbar__mobile-menu

        absolute top-0 left-0 w-full bg-grey-100 text-black pb-16 font-alt text-4xl drop-shadow-lg
        flex-col gap-3
      "
    >
      <div class="grid-container">
        <div class="grid-left-side">
          {% if page.root_page.show_logo is not False %}
            {% block popout_logo_image %}
              <img
                class="w-[150px] mt-3"
                src="{% if dark_logo %}{{ dark_logo.url }}{% else %}{% static 'styleguide2/images/logo-full-black.svg' %}{% endif %}"
                alt="Pirátské logo"
              >
            {% endblock %}
          {% endif %}
        </div>
      </div>

      <div
        class="
          __navbar-search

          flex flex-col gap-8 md:flex-row pt-6 px-8
          md:justify-between
          xl:pl-32
        "
      >
        <div class="flex flex-col gap-1.5 items-start">
          {% if page.root_page.search_page %}
            <form
              method="GET"
              action="{{ page.root_page.search_page.url }}"
              class="block w-full mb-8 flex"
            >
              {% include 'styleguide2/includes/atoms/form_fields/form_input.html' with placeholder='Hledej' classes='text-black px-2 py-1 w-full' name='q' value=global_search_query %}
            </form>
          {% endif %}

          {% if page.root_page.important_item_name %}
            {% firstof page.root_page.important_item_page.url page.root_page.important_item_url as target %}

            <a
              href="{{ target }}"
              class="
                __js-root flex items-center decoration-1 underline-offset-4

                navbar__menu-item

                {% if selected_item == page.root_page.important_item_name %}navbar__menu-item--selected{% endif %}
              "
            >
              <div class="mb-1">
                <ui-animated-arrow
                  :mobile-width="40"
                  :mobile-height="42"
                ></ui-animated-arrow>
              </div>

              {{ page.root_page.important_item_name }}
            </a>
          {% endif %}

          {% for menu in page.root_page.menu %}
            {% if menu.block_type == "menu_item" %}
              {% firstof menu.value.page.url menu.value.link as target %}

              <a
                href="{{ target }}"
                class="
                  decoration-1 underline-offset-4

                  navbar__menu-item

                  {% if menu.value.title == selected_item %}navbar__menu-item--selected{% endif %}
                "
              >{{ menu.value.title }}</a>
            {% elif menu.block_type == "menu_parent" %}
              {% for child_item in menu.value.menu_items %}
                {% firstof child_item.page.url child_item.link as target %}

                <a
                  href="{{ target }}"
                  class="
                    decoration-1 underline-offset-4

                    navbar__menu-item

                    {% if child_item.title == selected_item %}navbar__menu-item--selected{% endif %}
                  "
                >{{ child_item.title }}</a>
              {% endfor %}
            {% endif %}
          {% endfor %}
          <div class="mt-6"></div>

          {% if page.root_page.menu_button_content %}
            <div class="mb-6 flex flex-col gap-1.5">
              {% for button in page.root_page.menu_button_content %}
                <a
                  href="{{ button.value.button_link }}"
                  class="
                    decoration-1 underline-offset-4

                    navbar__menu-item

                    {% if button.value.button_text == selected_item %}navbar__menu-item--selected{% endif %}
                  "
                >{{ button.value.button_text }}</a>
              {% endfor %}
            </div>
          {% endif %}

          {% if page.root_page.popout_button_content %}
            <div class="mb-6 flex flex-col gap-1.5">
              {% for button in page.root_page.popout_button_content %}
                <a
                  href="{{ button.value.button_link }}"
                  class="
                    decoration-1 underline-offset-4

                    navbar__menu-item

                    {% if button.value.button_text == selected_item %}navbar__menu-item--selected{% endif %}
                  "
                >{{ button.value.button_text }}</a>
              {% endfor %}
            </div>
          {% endif %}
        </div>

        <div class="flex gap-5 text-lg md:justify-end">
          {% for social_link_block in page.root_page.social_links %}
            <a href="{{ social_link_block.value.link }}" class="hover:no-underline">
              <i class="{{ social_link_block.value.icon }}"></i>
            </a>
          {% endfor %}
        </div>
      </div>
    </div>
  </div>
</nav>

{% block observer_script %}
  <script>
    const navbar = document.querySelector("#navbar")

    const transparentClass = "{% block observer_script_toggled_class %}navbar--transparent{% endblock %}"
    let initiallyHadTransparentClass = false

    if (navbar.classList.contains(transparentClass)) {
      initiallyHadTransparentClass = true
    }

    console.log(initiallyHadTransparentClass)

    window.onscroll = () => {
      const screenWidth = Math.max(document.documentElement.clientWidth || 0, window.innerWidth || 0)

      {% if not page.root_page.has_expanded_navbar %}
        if (screenWidth > 1199) {
          return
        }
      {% endif %}

      if (window.scrollY === 0) {
        if (initiallyHadTransparentClass) {
          navbar.classList.add(transparentClass)
        }
      } else {
        navbar.classList.remove(transparentClass)
      }
    }

    const menuItems = document.querySelectorAll(".navbar__menu-item")

    menuItems.forEach(
      (element) => {
        element.addEventListener(
          "click",
          (event) => {
            document.getElementById("navbar__mobile-menu__toggle").checked = false
          }
        )
      }
    )
  </script>
{% endblock %}