<template>
  <div>
    <div class="md:flex">
      <div class="w-full md:w-1/3 lg:w-1/4 flex items-center">
        <div class="w-3/4 py-5">
          <div class="text-sm">
            <a
              href="/"
              class="text-black"
              tabindex="-1"
            >
              {{ siteTitle }}
            </a>
          </div>
        </div>

        <div class="w-1/4 text-right md:hidden">
          <button
            type="button"
            class="nav-toggle appearance-none"
            aria-label="Toggle main menu"
            @click="hidden = !hidden"
          >
            <svg
              class="fill-current text-gray-600 w-6 h-6"
              xmlns="http://www.w3.org/2000/svg"
              viewBox="0 0 20 20"
            >
              <path d="M16.4 9H3.6c-.552 0-.6.447-.6 1 0 .553.048 1 .6 1h12.8c.552 0 .6-.447.6-1 0-.553-.048-1-.6-1zm0 4H3.6c-.552 0-.6.447-.6 1 0 .553.048 1 .6 1h12.8c.552 0 .6-.447.6-1 0-.553-.048-1-.6-1zM3.6 7h12.8c.552 0 .6-.447.6-1 0-.553-.048-1-.6-1H3.6c-.552 0-.6.447-.6 1 0 .553.048 1 .6 1z" />
            </svg>
          </button>
        </div>
      </div>

      <nav
        class="w-full -mx-4 mt-px md:mt-0 md:mx-0 block md:flex md:flex-wrap md:flex-1 md:justify-end bg-white absolute md:relative border-b md:border-b-0"
        :class="{hidden: hidden}"
        role="navigation"
      >
        <a
          v-for="(item, index) in items"
          :key="index"
          class="block text-black no-underline focus:outline-none p-4 border-l-3 md:border-l-0 md:border-b-3 border-transparent hover:border-gray-300 focus:border-gray-300 focus:bg-white md:ml-4 md:mr-0 md:p-0 hover:no-underline text-sm -mb-px"
          :class="{'border-blue-600 hover:border-blue-600': isActive(item)}"
          :href="item.href"
        >
          <span class="flex items-center h-full">{{ item.title }}</span>
        </a>
      </nav>
    </div>
  </div>
</template>

<script>
export default {
  props: {
    siteTitle: {
      type: String,
      required: true
    },
    pageUrl: {
      type: String,
      required: true
    }
  },

  data() {
    return {
      hidden: true,

      items: [
        {
          title: 'About',
          href: '/',
          pattern: '^/.$',
        },
        {
          title: 'Projects',
          href: '/projects',
          pattern: '^/projects/?$',
        },
        {
          title: 'Articles',
          href: '/articles',
          pattern: '^/articles/?',
        },
        {
          title: 'Talks',
          href: '/talks',
          pattern: '^/talks/?',
        },
        {
          title: 'Podcasts',
          href: '/podcasts',
          pattern: '^/podcasts/?',
        },
        {
          title: 'Book',
          href: '/test-driven-drupal',
          pattern: '^/test-driven-drupal/?$',
        },
        {
          title: 'Contact',
          href: '/contact',
          pattern: '^/contact/?',
        },
      ],
    }
  },


  methods: {
    isActive(item) {
      return this.pageUrl.match(new RegExp(item.pattern))
    }
  }
}
</script>