| 
									
										
										
										
											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-09-25 19:45:06 +08:00
										 |  |  |             :expand-on-click-node="false" | 
					
						
							| 
									
										
										
										
											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) { | 
					
						
							| 
									
										
										
										
											2025-09-25 19:45:06 +08:00
										 |  |  |       this.$router.push({ | 
					
						
							|  |  |  |         path: `${this.baseUrl}`, | 
					
						
							|  |  |  |         query: { | 
					
						
							|  |  |  |           ...this.$route.query, | 
					
						
							|  |  |  |           catgId: row.id, | 
					
						
							|  |  |  |           title: node.data.label | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2025-07-15 22:54:24 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											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> |