<template>
  <q-layout view="hHh lpr lFf">
    <q-header elevated class="bg-primary text-white">
      <q-toolbar>
        <!-- Button um Navigationsleiset ein und auszublenden. Nötig bei Desktop? -->
        <q-btn
          dense
          flat
          round
          icon="menu"
          @click="leftDrawerOpen = !leftDrawerOpen"
          v-if="!leftDrawerOpen"
        />

        <q-toolbar-title>
          <q-avatar>
            <img src="logo.svg" />
          </q-avatar>
          <span class="gt-xs">
            Flaschengeist
          </span>
        </q-toolbar-title>

        <!-- Hier kommen die Shortlinks hin -->
        <div>
          <q-btn flat round dense icon="sim_card" />
          <q-btn flat round dense icon="gamepad" />
        </div>
        <q-btn
          flat
          round
          dense
          icon="mdi-exit-to-app"
          @click="$router.push({ name: 'login' })"
        />
      </q-toolbar>
    </q-header>

    <q-drawer
      show-if-above
      v-model="leftDrawerOpen"
      side="left"
      bordered
      :mini="leftDrawerMini"
      @click.capture="leftDrawerClicker"
    >
      <!-- Plugins -->
      <q-list>
        <essential-link
          v-for="(link, index) in links"
          :key="index"
          :title="link.title"
          :link="link.link"
          :icon="link.icon"
        />
      </q-list>
      <q-separator />

      <!-- Plugin functions -->
      <router-view name="plugin-nav" />

      <div class="q-mini-drawer-hide absolute" style="top: 15px; right: -11px">
        <q-btn
          size="sm"
          dense
          round
          unelevated
          color="secondary"
          icon="chevron_left"
          @click="leftDrawerMini = true"
        />
      </div>
    </q-drawer>

    <q-page-container>
      <router-view />
    </q-page-container>
  </q-layout>
</template>

<script lang="ts">
import EssentialLink from 'components/navigation/EssentialLink.vue';
import { event, Screen } from 'quasar';
import { defineComponent, ref, reactive, computed } from '@vue/composition-api';

const links = [
  { title: 'home', icon: 'mdi-home' },
  { title: 'about', link: 'about', icon: 'mdi-information' }
];

export default defineComponent({
  name: 'MainLayout',
  components: { EssentialLink },
  setup() {
    const leftDrawer = ref(false);

    const leftDrawerOpen = ref(
      computed({
        get: () => (leftDrawer.value || Screen.gt.sm ? true : false),
        set: (val: boolean) => (leftDrawer.value = val)
      })
    );
    const leftDrawerMini = ref(false);
    function leftDrawerClicker() {
      if (leftDrawerMini.value) {
        leftDrawerMini.value = false;
      }
    }

    return { leftDrawerOpen, leftDrawerMini, leftDrawerClicker, links };
  }
});
</script>