MobileHeader.vue 3.88 KB
<template>
  <!-- <div class="bg-grey-lighten-3 tw-w-full tw-h-[60px]"></div> -->
  <!-- color="grey-lighten-3" -->
  <v-card class="mx-auto !tw-z-10" max-width="" height="60">
    <v-layout>
      <v-app-bar scroll-behavior="elevate" color="white" density="default">
        <v-app-bar-title v-if="!showSearch">
          <a href="/"><v-img src="/mobile/index-logo.png" alt="canrud" width="100" height="40" /></a>
        </v-app-bar-title>
        <template v-slot:append>
          <v-btn icon v-if="!showSearch">
            <v-icon @click="showSearch = !showSearch">mdi-magnify</v-icon>
          </v-btn>

          <v-app-bar-nav-icon @click="drawer = !drawer" v-if="!drawer"></v-app-bar-nav-icon>
          <v-app-bar-nav-icon @click="drawer = !drawer" v-if="drawer" icon="mdi-window-close"></v-app-bar-nav-icon>
        </template>

        <div class="tw-h-[36px] tw-w-[300px] ml-8" v-if="showSearch">
          <v-text-field dense density="compact" height="24" label="Search keyword" hide-details="auto" variant="solo"
            append-inner-icon="mdi-close" @click:appendInner="handleClick" @keydown="handleKeyDown" v-model="input">
          </v-text-field>
        </div>
      </v-app-bar>

      <v-navigation-drawer width="512" v-model="drawer" location="right" temporary floating>
        <v-list density="compact" nav>
          <v-list-item to="/" title="Home" value="home" @click="handleTabClick" color="blue-darken-1">
          </v-list-item>
          <v-divider></v-divider>
          <v-list-item to="/products" title="Products" value="Products" @click="handleTabClick"
            color="blue-darken-1"></v-list-item>
          <v-divider></v-divider>
          <v-list-item to="/about" title="About" value="about" @click="handleTabClick"
            color="blue-darken-1"></v-list-item>
          <v-divider></v-divider>
          <v-list-item to="/contact" title="Contact" value="contact" @click="handleTabClick"
            color="blue-darken-1"></v-list-item>
        </v-list>
      </v-navigation-drawer>
    </v-layout>
  </v-card>
  <!-- <v-container>
    <v-row class="tw-m-auto tw-flex tw-items-center">
      <v-col cols="2" class="pa-0 tw-h-[64px]">
        <router-link to="/"><v-img src="/logo.jpg" alt="canrud" /></router-link>
      </v-col>
      <v-col cols="6" md="8" class="px-0">
        <v-text-field
          label="Search keyword"
          hide-details="auto"
          variant="solo"
          append-inner-icon="mdi-magnify"
          @click:appendInner="handleClick"
          @keydown="handleKeyDown"
          v-model="input"
        >
        </v-text-field>
      </v-col>
      <v-col cols="4" md="2" class="px-0">
        <v-btn variant="text" @click="dialogStore.updateDialog(true)" color="blue-darken-2 mt-4"
          >Concat Us
        </v-btn>
      </v-col>
    </v-row>
  </v-container> -->

  <ContactDialog />
</template>

<script setup lang="ts">
import { ref, watchEffect } from 'vue'
import { useProductListStore } from '@/stores/product_list'
import { useRouter } from 'vue-router'
import { useDialogStore } from '@/stores/dialog'
import { useCategoryStore } from '@/stores/category'
import { useDisplay } from 'vuetify'

const drawer = ref(false)
const showSearch = ref(false)

const productStore = useProductListStore()
const categoryStore = useCategoryStore()

const input = ref()

const router = useRouter()

const handleKeyDown = (e: any) => {
  if (e.keyCode == 13) {
    categoryStore.updateDisplay(!input.value)
    productStore.updateKeyword(input.value)
    productStore.updatePageNo(1)
    router.push('/products')
  }
}

const handleClick = () => {
  showSearch.value = false
}

const handleTabClick = () => {
  categoryStore.updateDisplay(true)
  productStore.updateKeyword('')
}

watchEffect(() => {
  input.value = productStore.keyword
})
</script>

<style lang="scss" scoped>
.tabs {
  background-color: #1f88e5;
}

.active :deep {
  .v-tab__slider {
    bottom: 3px;
  }
}
</style>