BasicLayout.vue 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <template>
  2. <a-layout :class="['layout', device]">
  3. <!-- SideMenu -->
  4. <a-drawer
  5. v-if="isMobile()"
  6. placement="left"
  7. :wrapClassName="`drawer-sider ${navTheme}`"
  8. :closable="false"
  9. :visible="collapsed"
  10. @close="drawerClose"
  11. >
  12. <side-menu
  13. mode="inline"
  14. :menus="menus"
  15. :theme="navTheme"
  16. :collapsed="false"
  17. :collapsible="true"
  18. @menuSelect="menuSelect"
  19. ></side-menu>
  20. </a-drawer>
  21. <side-menu
  22. v-else-if="isSideMenu()"
  23. mode="inline"
  24. :menus="menus"
  25. :theme="navTheme"
  26. :collapsed="collapsed"
  27. :collapsible="true"
  28. ></side-menu>
  29. <a-layout :class="[layoutMode, `content-width-${contentWidth}`]" :style="{ paddingLeft: contentPaddingLeft, minHeight: '100vh' }">
  30. <!-- layout header -->
  31. <global-header
  32. :mode="layoutMode"
  33. :menus="menus"
  34. :theme="navTheme"
  35. :collapsed="collapsed"
  36. :device="device"
  37. @toggle="toggle"
  38. />
  39. <!-- layout content -->
  40. <a-layout-content :style="{ height: '100%', margin: '24px 24px 0', paddingTop: fixedHeader ? '64px' : '0' }">
  41. <multi-tab v-if="multiTab"></multi-tab>
  42. <transition name="page-transition">
  43. <route-view />
  44. </transition>
  45. </a-layout-content>
  46. <!-- layout footer -->
  47. <a-layout-footer>
  48. <global-footer />
  49. </a-layout-footer>
  50. <!-- Setting Drawer (show in development mode) -->
  51. <!-- <setting-drawer v-if="!production"></setting-drawer>-->
  52. </a-layout>
  53. </a-layout>
  54. </template>
  55. <script>
  56. import { triggerWindowResizeEvent } from '@/utils/util'
  57. import { mapState, mapActions } from 'vuex'
  58. import { mixin, mixinDevice } from '@/utils/mixin'
  59. import config from '@/config/defaultSettings'
  60. import RouteView from './RouteView'
  61. import SideMenu from '@/components/Menu/SideMenu'
  62. import GlobalHeader from '@/components/GlobalHeader'
  63. import GlobalFooter from '@/components/GlobalFooter'
  64. import SettingDrawer from '@/components/SettingDrawer'
  65. export default {
  66. name: 'BasicLayout',
  67. mixins: [mixin, mixinDevice],
  68. components: {
  69. RouteView,
  70. SideMenu,
  71. GlobalHeader,
  72. GlobalFooter,
  73. SettingDrawer
  74. },
  75. data () {
  76. return {
  77. production: config.production,
  78. collapsed: false,
  79. menus: []
  80. }
  81. },
  82. computed: {
  83. ...mapState({
  84. // 动态主路由
  85. mainMenu: state => state.permission.addRouters
  86. }),
  87. contentPaddingLeft () {
  88. if (!this.fixSidebar || this.isMobile()) {
  89. return '0'
  90. }
  91. if (this.sidebarOpened) {
  92. return '256px'
  93. }
  94. return '80px'
  95. }
  96. },
  97. watch: {
  98. sidebarOpened (val) {
  99. this.collapsed = !val
  100. }
  101. },
  102. created () {
  103. this.menus = this.mainMenu.find(item => item.path === '/').children
  104. this.collapsed = !this.sidebarOpened
  105. },
  106. mounted () {
  107. const userAgent = navigator.userAgent
  108. if (userAgent.indexOf('Edge') > -1) {
  109. this.$nextTick(() => {
  110. this.collapsed = !this.collapsed
  111. setTimeout(() => {
  112. this.collapsed = !this.collapsed
  113. }, 16)
  114. })
  115. }
  116. },
  117. methods: {
  118. ...mapActions(['setSidebar']),
  119. toggle () {
  120. this.collapsed = !this.collapsed
  121. this.setSidebar(!this.collapsed)
  122. triggerWindowResizeEvent()
  123. },
  124. paddingCalc () {
  125. let left = ''
  126. if (this.sidebarOpened) {
  127. left = this.isDesktop() ? '256px' : '80px'
  128. } else {
  129. left = (this.isMobile() && '0') || ((this.fixSidebar && '80px') || '0')
  130. }
  131. return left
  132. },
  133. menuSelect () {
  134. },
  135. drawerClose () {
  136. this.collapsed = false
  137. }
  138. }
  139. }
  140. </script>
  141. <style lang="less">
  142. /*
  143. * The following styles are auto-applied to elements with
  144. * transition="page-transition" when their visibility is toggled
  145. * by Vue.js.
  146. *
  147. * You can easily play with the page transition by editing
  148. * these styles.
  149. */
  150. .page-transition-enter {
  151. opacity: 0;
  152. }
  153. .page-transition-leave-active {
  154. opacity: 0;
  155. }
  156. .page-transition-enter .page-transition-container,
  157. .page-transition-leave-active .page-transition-container {
  158. -webkit-transform: scale(1.1);
  159. transform: scale(1.1);
  160. }
  161. </style>