Header.vue 1.72 KB
<template>
  <v-container>
    <div class="tw-m-auto">
      <div class="tw-mr-[8px] tw-float-left tw-h-[64px] tw-mt-[-4px] tw-w-[100px]">
        <router-link to="/"><v-img src="/logo.jpg" /></router-link>
      </div>
      <div class="tw-m-auto">
        <v-text-field
          density="comfortable"
          label="Search keyword"
          hide-details="auto"
          variant="solo"
          append-inner-icon="mdi-magnify"
          @click:appendInner="handleClick"
          v-model="input"
        ></v-text-field>
      </div>
    </div>
  </v-container>
  <div class="tabs">
    <div class="tw-max-w-[1200px] tw-mx-auto">
      <v-tabs
        v-model="tab"
        bg-color="blue-darken-1"
        slider-color="grey-lighten-3"
        tab-slider-size="6px"
        selected-class="active"
      >
        <v-tab :value="1" to="/"><span class="text-grey-lighten-3 tw-font-bold">Home</span> </v-tab>
        <v-tab :value="2" to="/products"
          ><span class="text-grey-lighten-3 tw-font-bold">Products</span></v-tab
        >
        <v-tab :value="3" to="/about"
          ><span class="text-grey-lighten-3 tw-font-bold">About</span></v-tab
        >
        <v-tab :value="4" to="/contact"
          ><span class="text-grey-lighten-3 tw-font-bold">Contact</span></v-tab
        >
      </v-tabs>
    </div>
  </div>
</template>

<script setup lang="ts">
import { ref } from 'vue'
import { useProductListStore } from '@/stores/product_list'

const productStore = useProductListStore()

const input = ref()

const handleClick = () => {
  productStore.updateKeyword(input.value)
}

const tab = ref(1)
</script>

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

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