| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <div class="side-content"> | 
					
						
							| 
									
										
										
										
											2025-09-11 21:51:38 +08:00
										 |  |  |     <no-ssr> | 
					
						
							|  |  |  |       <ul class="side-nav"> | 
					
						
							|  |  |  |         <li  | 
					
						
							|  |  |  |           class="side-item"  | 
					
						
							|  |  |  |           v-for="(item, index) in sideiItem"  | 
					
						
							|  |  |  |           :key="index" | 
					
						
							|  |  |  |           @click="jump(item)" | 
					
						
							|  |  |  |         > | 
					
						
							|  |  |  |           <div class="side-label"> | 
					
						
							|  |  |  |             <img :src="item.icon" :alt="item.label" /> | 
					
						
							|  |  |  |             <h4>{{ item.label }}</h4> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |           <div v-if="item.desc" class="side-desc" v-html="item.desc"></div> | 
					
						
							|  |  |  |         </li> | 
					
						
							|  |  |  |       </ul> | 
					
						
							|  |  |  |     </no-ssr> | 
					
						
							| 
									
										
										
										
											2025-09-02 09:46:44 +08:00
										 |  |  |     <div class="top-btn" @click="goTop"> | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |       <div class="side-label"> | 
					
						
							|  |  |  |         <img src="~/assets//image/icon/top.png" alt="返回顶部" /> | 
					
						
							|  |  |  |         <h4>{{ $t('common.TOP') }}</h4> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  | import { mapState } from 'vuex'; | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   name: 'SideNav', | 
					
						
							|  |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							| 
									
										
										
										
											2025-09-11 21:51:38 +08:00
										 |  |  |       maxCatgId: '' | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   computed: { | 
					
						
							|  |  |  |     ...mapState({ | 
					
						
							|  |  |  |       footerInfo: state => state.footerInfo | 
					
						
							|  |  |  |     }), | 
					
						
							|  |  |  |     sideiItem() { | 
					
						
							|  |  |  |       return [ | 
					
						
							| 
									
										
										
										
											2025-09-11 16:15:34 +08:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |           icon: require('../assets/image/icon/contact.png'), | 
					
						
							|  |  |  |           label: this.$t('common.Contact'), | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |           url: `tel:${this.footerInfo.tel}`, | 
					
						
							| 
									
										
										
										
											2025-09-16 21:31:24 +08:00
										 |  |  |           thirdSoft: 'Tel', | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |           desc: `<div">
 | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |               <h6>${this.$t('contactUs.contactUs')}</h6> | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |               <p>${this.footerInfo.tel}</p> | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |             </div>`
 | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2025-09-11 16:15:34 +08:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |           icon: require('../assets/image/icon/online.png'), | 
					
						
							|  |  |  |           label: this.$t('common.Online'), | 
					
						
							| 
									
										
										
										
											2025-09-11 21:51:38 +08:00
										 |  |  |           url: `/inquiry?maxCatgId=${this.maxCatgId}` | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2025-09-11 16:15:34 +08:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |           icon: require('../assets/image/icon/whats.png'), | 
					
						
							|  |  |  |           label: this.$t('common.Whats'), | 
					
						
							| 
									
										
										
										
											2025-09-16 21:31:24 +08:00
										 |  |  |           thirdSoft: 'WhatsApp', | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |           url: `https://wa.me/${this.footerInfo.whatsapp}`, | 
					
						
							|  |  |  |           desc: `<div>
 | 
					
						
							|  |  |  |             <h6>${this.$t('common.Whats')}</h6> | 
					
						
							|  |  |  |             <p>${this.footerInfo.whatsapp}</p> | 
					
						
							|  |  |  |           </div>`
 | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2025-09-11 16:15:34 +08:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |           icon: require('../assets/image/icon/email1.png'), | 
					
						
							|  |  |  |           label: this.$t('common.E-mail'), | 
					
						
							| 
									
										
										
										
											2025-09-16 21:31:24 +08:00
										 |  |  |           thirdSoft: 'Email', | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |           url: `mailto:${this.footerInfo.email}`, | 
					
						
							|  |  |  |           desc: `<div>
 | 
					
						
							|  |  |  |             <h6>${this.$t('common.E-mail')}</h6> | 
					
						
							|  |  |  |             <p>${this.footerInfo.email}</p> | 
					
						
							|  |  |  |           </div>`
 | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |         } | 
					
						
							|  |  |  |       ] | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2025-09-02 09:46:44 +08:00
										 |  |  |   }, | 
					
						
							| 
									
										
										
										
											2025-09-11 21:51:38 +08:00
										 |  |  |   beforeMount() { | 
					
						
							|  |  |  |     this.$axios.get('/web/getCatgIdApp?catgName=Contact').then(res => { | 
					
						
							|  |  |  |       this.maxCatgId = res.data | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2025-09-02 09:46:44 +08:00
										 |  |  |   methods:{ | 
					
						
							| 
									
										
										
										
											2025-09-16 21:31:24 +08:00
										 |  |  |     async jump(row) { | 
					
						
							| 
									
										
										
										
											2025-09-17 15:37:04 +08:00
										 |  |  |       let thirdAccount = "" | 
					
						
							|  |  |  |       if("Tel"==row.thirdSoft){ | 
					
						
							|  |  |  |         thirdAccount=this.footerInfo.tel | 
					
						
							|  |  |  |       }else if ("WhatsApp"==row.thirdSoft){ | 
					
						
							|  |  |  |         thirdAccount=this.footerInfo.whatsapp | 
					
						
							|  |  |  |       }else if ("Email"==row.thirdSoft){ | 
					
						
							|  |  |  |         thirdAccount=this.footerInfo.email | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2025-09-16 21:31:24 +08:00
										 |  |  |       let data = { | 
					
						
							|  |  |  |         equipment: this.$store.state.device, | 
					
						
							|  |  |  |         thirdSoft: row.thirdSoft, | 
					
						
							| 
									
										
										
										
											2025-09-17 15:37:04 +08:00
										 |  |  |         thirdAccount: thirdAccount, | 
					
						
							| 
									
										
										
										
											2025-09-16 21:31:24 +08:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (row.thirdSoft) { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |           await this.$axios.post('/web/thirdItemSave', data) | 
					
						
							|  |  |  |         } catch(err) { | 
					
						
							|  |  |  |           console.log(err); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2025-09-11 21:24:04 +08:00
										 |  |  |       if (row.url) { | 
					
						
							|  |  |  |         window.open(row.url) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2025-09-02 09:46:44 +08:00
										 |  |  |     goTop() { | 
					
						
							|  |  |  |       window.scrollTo({ top: 0, behavior: 'smooth' }); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2025-07-31 00:01:12 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | .side-content { | 
					
						
							|  |  |  |   position: fixed; | 
					
						
							|  |  |  |   top: 40%; | 
					
						
							|  |  |  |   right: 1rem; | 
					
						
							|  |  |  |   z-index: 999; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | .side-nav { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   flex-direction: column; | 
					
						
							|  |  |  |   align-items: flex-end; | 
					
						
							|  |  |  |   @mixin active { | 
					
						
							|  |  |  |     .side-desc { | 
					
						
							|  |  |  |       width: max-content; | 
					
						
							|  |  |  |       padding: .625rem 1.375rem; | 
					
						
							|  |  |  |       visibility: visible; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .side-item { | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     cursor: pointer; | 
					
						
							|  |  |  |     &:hover { | 
					
						
							|  |  |  |       @include active; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     .side-label { | 
					
						
							|  |  |  |       width: 4.5rem; | 
					
						
							|  |  |  |       height: 4.5rem; | 
					
						
							|  |  |  |       display: flex; | 
					
						
							|  |  |  |       flex-direction: column; | 
					
						
							|  |  |  |       align-items: center; | 
					
						
							|  |  |  |       justify-content: center; | 
					
						
							|  |  |  |       background-color: #fff; | 
					
						
							|  |  |  |       box-shadow: 0px 2px 6px 1px rgba(1,95,232,0.13); | 
					
						
							|  |  |  |       img { | 
					
						
							|  |  |  |         width: 1.5rem; | 
					
						
							|  |  |  |         height: 1.5rem; | 
					
						
							|  |  |  |         margin-bottom: .3125rem; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       h4 { | 
					
						
							|  |  |  |         color: #323436; | 
					
						
							|  |  |  |         font-size: .75rem; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     .side-desc { | 
					
						
							|  |  |  |       width: 0; | 
					
						
							|  |  |  |       height: 4.5rem; | 
					
						
							|  |  |  |       visibility: hidden; | 
					
						
							|  |  |  |       background-color: #015fe8; | 
					
						
							|  |  |  |       color: #fff; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   .side-item-active { | 
					
						
							|  |  |  |     @include active; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .top-btn { | 
					
						
							|  |  |  |   margin-top: 1rem; | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   align-items: center; | 
					
						
							|  |  |  |   justify-content: flex-end; | 
					
						
							|  |  |  |   cursor: pointer; | 
					
						
							|  |  |  |   .side-label { | 
					
						
							|  |  |  |     width: 4.5rem; | 
					
						
							|  |  |  |     height: 4.5rem; | 
					
						
							|  |  |  |     display: flex; | 
					
						
							|  |  |  |     flex-direction: column; | 
					
						
							|  |  |  |     align-items: center; | 
					
						
							|  |  |  |     justify-content: center; | 
					
						
							|  |  |  |     background-color: #fff; | 
					
						
							|  |  |  |     box-shadow: 0px 2px 6px 1px rgba(1,95,232,0.13); | 
					
						
							|  |  |  |     img { | 
					
						
							|  |  |  |       width: 1.5rem; | 
					
						
							|  |  |  |       height: 1.5rem; | 
					
						
							|  |  |  |       margin-bottom: .3125rem; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     h4 { | 
					
						
							|  |  |  |       color: #323436; | 
					
						
							|  |  |  |       font-size: .75rem; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | </style> |