mirror of
				https://github.com/strapi/strapi.git
				synced 2025-10-25 06:51:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			141 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			141 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <div class="theme-container"
 | |
|     :class="pageClasses"
 | |
|     @touchstart="onTouchStart"
 | |
|     @touchend="onTouchEnd">
 | |
|     <Navbar v-if="shouldShowNavbar" @toggle-sidebar="toggleSidebar"/>
 | |
|     <div class="sidebar-mask" @click="toggleSidebar(false)"></div>
 | |
|     <Sidebar :items="sidebarItems" @toggle-sidebar="toggleSidebar" />
 | |
|     <div class="custom-layout" v-if="$page.frontmatter.layout">
 | |
|       <component :is="$page.frontmatter.layout"/>
 | |
|     </div>
 | |
|     <Home v-else-if="$page.frontmatter.home"/>
 | |
|     <Page v-else :sidebar-items="sidebarItems">
 | |
|       <slot name="page-top" slot="top"/>
 | |
|       <slot name="page-bottom" slot="bottom"/>
 | |
|     </Page>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| import Vue from 'vue'
 | |
| import nprogress from 'nprogress'
 | |
| import Home from './Home.vue'
 | |
| import Navbar from './Navbar.vue'
 | |
| import Page from './Page.vue'
 | |
| import Sidebar from './Sidebar.vue'
 | |
| import { resolveSidebarItems } from './util'
 | |
| 
 | |
| export default {
 | |
|   components: { Home, Page, Sidebar, Navbar },
 | |
|   data () {
 | |
|     return {
 | |
|       isSidebarOpen: false
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   computed: {
 | |
|     versions() {
 | |
|       const { themeConfig } = this.$site
 | |
|       return themeConfig.versions.map(version => ({
 | |
|         name: version[0],
 | |
|         path: version[1],
 | |
|       }))
 | |
|     },
 | |
|     shouldShowNavbar () {
 | |
|       const { themeConfig } = this.$site
 | |
|       const { frontmatter } = this.$page
 | |
|       if (
 | |
|         frontmatter.navbar === false ||
 | |
|         themeConfig.navbar === false) {
 | |
|         return false
 | |
|       }
 | |
|       return (
 | |
|         this.$title ||
 | |
|         themeConfig.logo ||
 | |
|         themeConfig.repo ||
 | |
|         themeConfig.nav ||
 | |
|         this.$themeLocaleConfig.nav
 | |
|       )
 | |
|     },
 | |
|     shouldShowSidebar () {
 | |
|       const { frontmatter } = this.$page
 | |
|       return (
 | |
|         !frontmatter.layout &&
 | |
|         !frontmatter.home &&
 | |
|         frontmatter.sidebar !== false &&
 | |
|         this.sidebarItems.length
 | |
|       )
 | |
|     },
 | |
|     sidebarItems () {
 | |
|       return resolveSidebarItems(
 | |
|         this.$page,
 | |
|         this.$route,
 | |
|         this.$site,
 | |
|         this.$localePath
 | |
|       )
 | |
|     },
 | |
|     pageClasses () {
 | |
|       const userPageClass = this.$page.frontmatter.pageClass
 | |
|       return [
 | |
|         {
 | |
|           'no-navbar': !this.shouldShowNavbar,
 | |
|           'sidebar-open': this.isSidebarOpen,
 | |
|           'no-sidebar': !this.shouldShowSidebar
 | |
|         },
 | |
|         userPageClass
 | |
|       ]
 | |
|     }
 | |
|   },
 | |
| 
 | |
|   mounted () {
 | |
|     window.addEventListener('scroll', this.onScroll)
 | |
| 
 | |
|     // configure progress bar
 | |
|     nprogress.configure({ showSpinner: false })
 | |
| 
 | |
|     this.$router.beforeEach((to, from, next) => {
 | |
|       if (to.path !== from.path && !Vue.component(to.name)) {
 | |
|         nprogress.start()
 | |
|       }
 | |
|       next()
 | |
|     })
 | |
| 
 | |
|     this.$router.afterEach(() => {
 | |
|       nprogress.done()
 | |
|       this.isSidebarOpen = false
 | |
|     })
 | |
|   },
 | |
| 
 | |
|   methods: {
 | |
|     changeVersion(to) {
 | |
|       this.$router.push(to)
 | |
|     },
 | |
|     toggleSidebar (to) {
 | |
|       this.isSidebarOpen = typeof to === 'boolean' ? to : !this.isSidebarOpen
 | |
|     },
 | |
|     // side swipe
 | |
|     onTouchStart (e) {
 | |
|       this.touchStart = {
 | |
|         x: e.changedTouches[0].clientX,
 | |
|         y: e.changedTouches[0].clientY
 | |
|       }
 | |
|     },
 | |
|     onTouchEnd (e) {
 | |
|       const dx = e.changedTouches[0].clientX - this.touchStart.x
 | |
|       const dy = e.changedTouches[0].clientY - this.touchStart.y
 | |
|       if (Math.abs(dx) > Math.abs(dy) && Math.abs(dx) > 40) {
 | |
|         if (dx > 0 && this.touchStart.x <= 80) {
 | |
|           this.toggleSidebar(true)
 | |
|         } else {
 | |
|           this.toggleSidebar(false)
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| </script>
 | |
| 
 | |
| <style src="prismjs/themes/prism-tomorrow.css"></style>
 | |
| <style src="./styles/theme.styl" lang="stylus"></style>
 | 
