dl_site_nuxt/components/aside-tree.vue

162 lines
3.4 KiB
Vue
Raw Normal View History

<template>
<aside class="aside-tree">
<div>
2025-07-15 22:54:24 +08:00
<nuxt-link class="aside-header" :to="baseUrl">
<h3>{{ headerTitle }}</h3>
</nuxt-link>
<nav class="tree-box">
<no-ssr>
<el-tree
v-if="refresh"
:data="treeData"
2025-07-29 23:28:46 +08:00
:empty-text="$t('common.empty')"
node-key="id"
highlight-current
2025-07-15 22:54:24 +08:00
default-expand-all
:props="props"
:current-node-key="currentNodeKey"
2025-07-15 22:54:24 +08:00
@current-change="handleNodeClick"
/>
2025-07-15 22:54:24 +08:00
</no-ssr>
</nav>
</div>
<div class="mt-2">
<h3 class="contact-us">{{ $t('contactUs.contactUs') }}</h3>
<div class="contact-details">
<h4 class="mt-3 mb-3">{{ $t('index.corporateName') }}</h4>
<p class="mb-2">
<label class="mb-0">{{ $t('common.addressLabel') }}:</label>
<span>{{ $t('aboutUs.address') }}</span>
</p>
<p class="mb-2">
<label class="mb-0">{{ $t('common.tel') }}:</label>
<span>+86-531-69985132</span>
</p>
<p class="mb-2">
<label class="mb-0">{{ $t('common.Mob/Whatsapp/Wechat') }}:</label>
<span>0086 182 5311 2969</span>
</p>
<p class="mb-2">
<label class="mb-0">{{ $t('common.E-mail') }}:</label>
<span>alicesales@scdtrailer.com</span>
</p>
</div>
</div>
</aside>
</template>
<script>
export default {
name: 'AsideTree',
props: {
headerTitle: {
type: String,
default: ''
},
treeData: {
type: Array,
default: () => []
},
props: {
type: Object,
default: () => {
return {
children: 'children',
label: 'label'
}
}
2025-07-15 22:54:24 +08:00
},
baseUrl: {
type: String,
default: '/'
}
},
data () {
2025-07-15 22:54:24 +08:00
return {
currentNodeKey: '',
refresh: true
2025-07-15 22:54:24 +08:00
}
},
watch: {
'$route.query.catgId': {
handler (val) {
this.refresh = false
2025-07-15 22:54:24 +08:00
this.currentNodeKey = val
this.$nextTick(() => {
this.refresh = true
})
},
immediate: true
2025-07-15 22:54:24 +08:00
}
},
mounted () {
2025-07-15 22:54:24 +08:00
},
methods: {
handleNodeClick(row,node) {
if (node.isLeaf) {
this.$router.push({
path: `${this.baseUrl}`,
query: {
...this.$route.query,
catgId: row.id
}
})
}
}
}
}
</script>
<style lang="scss" scoped>
@import "element-ui/lib/theme-chalk/tree.css";
@import "element-ui/lib/theme-chalk/menu.css";
@import "element-ui/lib/theme-chalk/scrollbar.css";
.aside-tree {
padding: 0;
@mixin header {
2025-07-15 22:54:24 +08:00
display: block;
margin: 0;
padding: 1.5rem 0;
text-indent: 2.125rem;
color: #fff;
background-color: #015fe8;
font-size: 1.25rem;
font-weight: bold;
}
.aside-header {
@include header;
}
.tree-box {
padding: .625rem .625rem;
border: .0625rem solid #d9dde0;
::v-deep .is-current {
> .el-tree-node__content {
color: #015fe8;
}
}
}
.contact-us {
@include header;
}
.contact-details {
padding: .625rem 1.25rem;
border: .0625rem solid #d9dde0;
background-color: #f5f7f9;
font-size: .875rem;
h4 {
color: #302d2d;
font-size: .875rem;
}
label {
color: #77778b;
}
}
}
// 特殊样式小屏幕处理
@media screen and (max-width:400px) {
}
</style>