2025-07-04 01:00:28 +08:00
|
|
|
<template>
|
|
|
|
<aside class="aside-tree">
|
2025-07-05 18:30:58 +08:00
|
|
|
<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>
|
2025-07-05 18:30:58 +08:00
|
|
|
<el-tree
|
2025-07-25 00:39:16 +08:00
|
|
|
v-if="refresh"
|
2025-07-05 18:30:58 +08:00
|
|
|
:data="treeData"
|
2025-07-29 23:28:46 +08:00
|
|
|
:empty-text="$t('common.empty')"
|
2025-07-05 18:30:58 +08:00
|
|
|
node-key="id"
|
|
|
|
highlight-current
|
2025-07-15 22:54:24 +08:00
|
|
|
default-expand-all
|
2025-07-12 19:41:58 +08:00
|
|
|
:props="props"
|
2025-07-25 00:39:16 +08:00
|
|
|
:current-node-key="currentNodeKey"
|
2025-07-15 22:54:24 +08:00
|
|
|
@current-change="handleNodeClick"
|
2025-07-05 18:30:58 +08:00
|
|
|
/>
|
2025-07-15 22:54:24 +08:00
|
|
|
</no-ssr>
|
|
|
|
</nav>
|
2025-07-05 18:30:58 +08:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="mt-2">
|
|
|
|
<h3 class="contact-us">{{ $t('contactUs.contactUs') }}</h3>
|
|
|
|
<div class="contact-details">
|
2025-08-24 17:39:48 +08:00
|
|
|
<h4 class="mt-3 mb-3">{{ footerInfo.companyName }}</h4>
|
2025-07-05 18:30:58 +08:00
|
|
|
<p class="mb-2">
|
|
|
|
<label class="mb-0">{{ $t('common.addressLabel') }}:</label>
|
2025-08-24 17:39:48 +08:00
|
|
|
<span>{{ footerInfo.address }}</span>
|
2025-07-05 18:30:58 +08:00
|
|
|
</p>
|
|
|
|
<p class="mb-2">
|
|
|
|
<label class="mb-0">{{ $t('common.tel') }}:</label>
|
2025-08-24 17:39:48 +08:00
|
|
|
<span>{{ footerInfo.tel }}</span>
|
2025-07-05 18:30:58 +08:00
|
|
|
</p>
|
|
|
|
<p class="mb-2">
|
|
|
|
<label class="mb-0">{{ $t('common.Mob/Whatsapp/Wechat') }}:</label>
|
2025-08-25 21:11:18 +08:00
|
|
|
<span>{{ footerInfo.whatsapp }}</span>
|
2025-07-05 18:30:58 +08:00
|
|
|
</p>
|
|
|
|
<p class="mb-2">
|
|
|
|
<label class="mb-0">{{ $t('common.E-mail') }}:</label>
|
2025-08-24 17:39:48 +08:00
|
|
|
<span>{{ footerInfo.email }}</span>
|
2025-07-05 18:30:58 +08:00
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
2025-07-04 01:00:28 +08:00
|
|
|
</aside>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2025-08-24 17:39:48 +08:00
|
|
|
import { mapState } from 'vuex';
|
|
|
|
|
2025-07-04 01:00:28 +08:00
|
|
|
export default {
|
|
|
|
name: 'AsideTree',
|
|
|
|
props: {
|
|
|
|
headerTitle: {
|
|
|
|
type: String,
|
|
|
|
default: ''
|
2025-07-12 19:41:58 +08:00
|
|
|
},
|
|
|
|
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: '/'
|
2025-07-04 01:00:28 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
data () {
|
2025-07-15 22:54:24 +08:00
|
|
|
return {
|
2025-07-25 00:39:16 +08:00
|
|
|
currentNodeKey: '',
|
|
|
|
refresh: true
|
2025-07-15 22:54:24 +08:00
|
|
|
}
|
|
|
|
},
|
2025-08-24 17:39:48 +08:00
|
|
|
computed: {
|
|
|
|
...mapState(['footerInfo'])
|
|
|
|
},
|
2025-07-15 22:54:24 +08:00
|
|
|
watch: {
|
|
|
|
'$route.query.catgId': {
|
|
|
|
handler (val) {
|
2025-07-25 00:39:16 +08:00
|
|
|
this.refresh = false
|
2025-07-15 22:54:24 +08:00
|
|
|
this.currentNodeKey = val
|
2025-07-25 00:39:16 +08:00
|
|
|
this.$nextTick(() => {
|
|
|
|
this.refresh = true
|
|
|
|
})
|
|
|
|
},
|
|
|
|
immediate: true
|
2025-07-15 22:54:24 +08:00
|
|
|
}
|
2025-07-04 01:00:28 +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
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2025-07-04 01:00:28 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
</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;
|
2025-07-05 18:30:58 +08:00
|
|
|
@mixin header {
|
2025-07-15 22:54:24 +08:00
|
|
|
display: block;
|
2025-07-04 01:00:28 +08:00
|
|
|
margin: 0;
|
|
|
|
padding: 1.5rem 0;
|
|
|
|
text-indent: 2.125rem;
|
|
|
|
color: #fff;
|
|
|
|
background-color: #015fe8;
|
|
|
|
font-size: 1.25rem;
|
|
|
|
font-weight: bold;
|
|
|
|
}
|
2025-07-05 18:30:58 +08:00
|
|
|
.aside-header {
|
|
|
|
@include header;
|
|
|
|
}
|
2025-07-04 01:00:28 +08:00
|
|
|
.tree-box {
|
|
|
|
padding: .625rem .625rem;
|
|
|
|
border: .0625rem solid #d9dde0;
|
2025-07-05 18:30:58 +08:00
|
|
|
::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;
|
|
|
|
}
|
2025-07-04 01:00:28 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 特殊样式小屏幕处理
|
|
|
|
@media screen and (max-width:400px) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
</style>
|