MobileCategoryList.vue 6.05 KB
<template>
  <div
    class="pr-4 tw-h-[48px] tw-leading-[48px] border-b tw-flex tw-justify-between tw-items-center"
  >
    <span class="ml-4 tw-font-bold">{{ categoryStore.selectedCategory }}</span>
    <span class="ml-1 text-grey-darken-4 text-body-2" @click="drawerVis = !drawerVis"
      >Filter <v-icon> mdi-filter-outline </v-icon></span
    >
  </div>
  <!-- <div class="bg-grey-lighten-4 tw-w-full tw-h-3"></div> -->
  <v-layout>
    <v-navigation-drawer
      @update:model-value="handleDrawerHide"
      v-model="drawerVis"
      location="bottom"
      touchless
      class="!tw-h-[70%]"
    >
      <v-row class="mb-4 ma-0">
        <v-col
          v-for="(item, index) in categoryStore.list"
          :key="index"
          cols="3"
          @click="handleCategoryClick(item, index)"
        >
          <v-img
            :src="
              categoryStore.selectedCategory === item.categoryDisplayName
                ? CATEGORY_IMG[index].selected
                : CATEGORY_IMG[index].normal
            "
          ></v-img>
          <!-- <v-img :src="item.normal" v-else></v-img> -->
          <!-- <v-img :src="item.selected"></v-img> -->
          <b class="tw-m-0 tw-inline">{{ item.categoryDisplayName }}</b>
        </v-col>
      </v-row>
      <v-list density="compact" :selected="[categoryStore.selectedSubCategory]">
        <v-list-subheader class="mb-2 !tw-font-bold text-subtitle-1">DEVICE TYPE</v-list-subheader>
        <v-list-item
          v-for="(item, i) in subCategoryList"
          :key="item.id"
          :value="item.id"
          color="blue-darken-1"
          @click="handleSubCategoryClick(item.id)"
        >
          <!-- <template v-slot:prepend>
            <v-icon :icon="item.icon"></v-icon>
          </template> -->

          <v-list-item-title>{{ item.name }}</v-list-item-title>
        </v-list-item>
      </v-list>
      <v-divider class="my-3" v-if="funcCategoryList.length"></v-divider>
      <v-list
        density="compact"
        v-if="funcCategoryList.length"
        :selected="[categoryStore.selectedFuncCategory]"
      >
        <v-list-subheader class="mb-2 !tw-font-bold text-subtitle-1">DEVICE TYPE</v-list-subheader>
        <v-list-item
          v-for="(item, i) in funcCategoryList"
          :key="item.id"
          :value="item.id"
          color="blue-darken-1"
          @click="handleFuncCategoryClick(item.id)"
        >
          <!-- <template v-slot:prepend>
            <v-icon :icon="item.icon"></v-icon>
          </template> -->

          <v-list-item-title>{{ item.name }}</v-list-item-title>
        </v-list-item>
      </v-list>
    </v-navigation-drawer>
  </v-layout>
</template>

<script setup lang="ts">
import { useCategoryStore } from '@/stores/category'
import { useProductListStore } from '@/stores/product_list'
import type { CategoryRootType } from '@/type'
import { computed, ref, watchEffect } from 'vue'
import { useRouter } from 'vue-router'

const router = useRouter()

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

const drawerVis = ref(false)

const CATEGORY_IMG = [
  { normal: '/category/1.png', selected: '/category/1.1.png', name: 'Energy materials' },
  { normal: '/category/2.png', selected: '/category/2.1.png', name: 'Laboratory consumables' },
  { normal: '/category/3.png', selected: '/category/3.1.png', name: 'Low-dimensional materials' },
  { normal: '/category/4.png', selected: '/category/4.1.png', name: 'Equipment' }
]

const SEO = {
  'Energy materials':
    'Energy materials,Not specified,Battery accessories,Lithium-ion batteries,Capacitors,Sodium-ion batteries,Lithium-sulfur batteries,Potassium/magnesium/aluminum/zinc batteries,Air/fuel/solar,Analytical electrodes,Complete battery accessories',
  'Laboratory consumables':
    'Laboratory consumables,Not specified,Glass materials,Plastic materials,Metal materials,Ceramic materials,Paper film materials,Chemical materials,Tetrafluoro materials,Safety protection,Office supplies,Tools,Others',
  'Low-dimensional materials':
    ',Low-dimensional materialsNot specified,Zero-dimensional carbon materials,One-dimensional carbon materials,Two-dimensional carbon materials,Three-dimensional carbon materials,Inorganic nanomaterials,Organic nanomaterials,Metal nanomaterials,Others',
  Equipment:
    'Equipment,Not specified,Equipment,Accessories & fixtures,Fuel cell manufacturing and testing equipment'
}

const handleDrawerHide = () => {
  productStore.updatePageNo(1)

  router.push({ query: { category: categoryStore.selectedCategory } })

  const doc = document as any
  const head = doc.getElementsByTagName('head')
  const meta = doc.createElement('meta')
  document.title = SEO[categoryStore.selectedCategory as keyof typeof SEO]
  doc
    .querySelector('meta[name="keywords"]')
    .setAttribute('content', SEO[categoryStore.selectedCategory as keyof typeof SEO])
  head[0].appendChild(meta)
}

const handleCategoryClick = (item: CategoryRootType, index: number) => {
  // if (categoryStore.selectedCategory === item.categoryDisplayName) {
  //   return categoryStore.updateCategory('')
  // }
  categoryStore.updateCategory(item.categoryDisplayName)
  categoryStore.updateSubCategory(item.list[0].id)

  if (index === 0) {
    categoryStore.updateFuncCategory(item.productFunctions[0].id)
  }
}

const handleSubCategoryClick = (value: string) => {
  // selectedSubCategory.value = value
  categoryStore.updateSubCategory(value)
}

const handleFuncCategoryClick = (value: string) => {
  categoryStore.updateFuncCategory(value)
  // selectedFuncCategory.value = value
}

const subCategoryList = computed(() => {
  if (categoryStore.selectedCategory) {
    const tmp = categoryStore.list.filter(
      (item) => item.categoryDisplayName === categoryStore.selectedCategory
    )
    return tmp?.[0]?.list || []
  }
  return []
})

const funcCategoryList = computed(() => {
  if (categoryStore.selectedCategory) {
    const tmp = categoryStore.list.filter(
      (item) => item.categoryDisplayName === categoryStore.selectedCategory
    )
    return tmp?.[0]?.productFunctions || []
  }
  return []
})
</script>

<style lang="less" scoped></style>