| 
									
										
										
										
											2023-03-11 14:42:02 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  |   <section class="app-main"> | 
					
						
							|  |  |  |     <transition name="fade-transform" mode="out-in"> | 
					
						
							|  |  |  |       <keep-alive :include="cachedViews"> | 
					
						
							|  |  |  |         <router-view v-if="!$route.meta.link" :key="key" /> | 
					
						
							|  |  |  |       </keep-alive> | 
					
						
							|  |  |  |     </transition> | 
					
						
							|  |  |  |     <iframe-toggle /> | 
					
						
							|  |  |  |   </section> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import iframeToggle from "./IframeToggle/index" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   name: 'AppMain', | 
					
						
							|  |  |  |   components: { iframeToggle }, | 
					
						
							|  |  |  |   computed: { | 
					
						
							|  |  |  |     cachedViews() { | 
					
						
							|  |  |  |       return this.$store.state.tagsView.cachedViews | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     key() { | 
					
						
							|  |  |  |       return this.$route.path | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-11-27 17:24:53 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  |   watch: { | 
					
						
							|  |  |  |     $route() { | 
					
						
							|  |  |  |       this.addIframe() | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   mounted() { | 
					
						
							|  |  |  |     this.addIframe() | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  |     addIframe() { | 
					
						
							|  |  |  |       const {name} = this.$route | 
					
						
							|  |  |  |       if (name && this.$route.meta.link) { | 
					
						
							|  |  |  |         this.$store.dispatch('tagsView/addIframeView', this.$route) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-03-11 14:42:02 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | .app-main { | 
					
						
							|  |  |  |   /* 50= navbar  50  */ | 
					
						
							|  |  |  |   min-height: calc(100vh - 50px); | 
					
						
							|  |  |  |   width: 100%; | 
					
						
							|  |  |  |   position: relative; | 
					
						
							|  |  |  |   overflow: hidden; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .fixed-header + .app-main { | 
					
						
							|  |  |  |   padding-top: 50px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .hasTagsView { | 
					
						
							|  |  |  |   .app-main { | 
					
						
							|  |  |  |     /* 84 = navbar + tags-view = 50 + 34 */ | 
					
						
							|  |  |  |     min-height: calc(100vh - 84px); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   .fixed-header + .app-main { | 
					
						
							|  |  |  |     padding-top: 84px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </style> | 
					
						
							| 
									
										
										
										
											2023-04-15 17:01:18 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss"> | 
					
						
							|  |  |  | // fix css style bug in open el-dialog
 | 
					
						
							|  |  |  | .el-popup-parent--hidden { | 
					
						
							|  |  |  |   .fixed-header { | 
					
						
							|  |  |  |     padding-right: 6px; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::-webkit-scrollbar { | 
					
						
							|  |  |  |   width: 6px; | 
					
						
							|  |  |  |   height: 6px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::-webkit-scrollbar-track { | 
					
						
							|  |  |  |   background-color: #f1f1f1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ::-webkit-scrollbar-thumb { | 
					
						
							|  |  |  |   background-color: #c0c0c0; | 
					
						
							|  |  |  |   border-radius: 3px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </style> |