layout.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375
  1. <template>
  2. <div
  3. :style="styleLayoutMainGroup"
  4. :class="{ grayMode: grayActive }"
  5. class="ibps-layout-header-aside-group hidden-print"
  6. >
  7. <!-- <iframe
  8. style="display: none;"
  9. id="iframeContain"
  10. name="iframeContain"
  11. seamless
  12. scrolling="yes"
  13. src=""
  14. >
  15. </iframe> -->
  16. <!-- 半透明遮罩 -->
  17. <div class="ibps-layout-header-aside-mask" />
  18. <!-- websocket -->
  19. <!-- <ibps-notify-monitor /> -->
  20. <!-- 主体内容 -->
  21. <div class="ibps-layout-header-aside-content" flex="dir:top">
  22. <panle />
  23. <!-- 顶栏 -->
  24. <div
  25. :style="{opacity: searchActive ? 0.5 : 1}"
  26. class="ibps-theme-header"
  27. style="box-shadow: 1px 4px 6px rgba(0, 0, 0, 0.12), 0 0 5px rgba(155, 155, 0, 0.04);margin-bottom: 5px;"
  28. flex-box="0"
  29. flex
  30. >
  31. <!-- <div
  32. :class="{'logo-group': true, 'logo-transition': asideTransition, 'ibps-pt-5': system.logoType === 'image', 'ibps-pl-0': system.logoType === 'image'}"
  33. :style="{width: asideCollapse ? asideWidthCollapse : asideWidth}"
  34. flex-box="0"
  35. >
  36. <el-dropdown
  37. v-if="subsystemList && subsystemList.length > 1"
  38. trigger="click"
  39. placement="bottom-start"
  40. @command="command => handleSubsystemClick(command)"
  41. >
  42. <ibps-logo
  43. :system="system"
  44. :aside-collapse="asideCollapse"
  45. :subsystem-list="subsystemList"
  46. :logo-icon-all="logoIconAll"
  47. :logo-icon-only="logoIconOnly"
  48. />
  49. <el-dropdown-menu slot="dropdown" style="width: 180px;">
  50. <el-dropdown-item
  51. v-for="(item, index) in subsystemList"
  52. :key="index"
  53. :disabled="item.id === system.id"
  54. :command="item"
  55. >
  56. <ibps-icon :name="item.logo || 'logo'" :title="item.name"/>{{ item.name }}
  57. </el-dropdown-item>
  58. </el-dropdown-menu>
  59. </el-dropdown>
  60. <ibps-logo
  61. v-else
  62. :system="system"
  63. :aside-collapse="asideCollapse"
  64. :subsystem-list="subsystemList"
  65. :logo-icon-all="logoIconAll"
  66. :logo-icon-only="logoIconOnly"
  67. />
  68. </div>
  69. <div
  70. class="toggle-aside-btn"
  71. flex-box="0"
  72. @click="handleToggleAside"
  73. >
  74. <ibps-icon :name="asideCollapse ? 'indent' : 'outdent'" />
  75. </div> -->
  76. <ibps-menu-header flex-box="1" @pageChange="pageChange" />
  77. <!-- 顶栏右侧 -->
  78. <div class="ibps-header-right" flex-box="0">
  79. <!-- 如果你只想在开发环境显示这个按钮请添加 v-if="$nodeEnv === 'development'" -->
  80. <!-- 全局搜索放大镜、日志、环境切换、全屏 -->
  81. <!-- <ibps-header-search @click="handleSearchClick" /> -->
  82. <ibps-header-error-log v-if="$nodeEnv === 'development'" />
  83. <ibps-header-base-url v-if="$nodeEnv === 'development'" />
  84. <!-- <ibps-header-download />
  85. <ibps-header-locking />
  86. <ibps-header-theme />
  87. <ibps-header-language />
  88. <ibps-header-size />
  89. <ibps-header-fullscreen />
  90. <ibps-header-tenant /> -->
  91. <ibps-header-clean-cache v-if="isSuper" type="platform" />
  92. <ibps-header-clean-cache v-if="isSuper" type="form" />
  93. <!-- <ibps-header-clean-cache v-if="isSuper" type="oauth" />
  94. <ibps-header-clean-cache v-if="isSuper" type="office" /> -->
  95. <span style="font-size: 12px; cursor: pointer;" @click="goToMain()">首页</span>
  96. <span style="margin: 0 10px;">|</span>
  97. <ibps-header-message />
  98. <!-- 消息中心 -->
  99. <span style="margin: 0 10px;">|</span>
  100. <ibps-header-user style="margin-right: 15px;"/>
  101. <!-- <span style="margin-left: 10px;">|</span>
  102. <ibps-header-setting /> -->
  103. </div>
  104. </div>
  105. <!-- 下面 主体 -->
  106. <div class="ibps-theme-container" flex-box="1" flex>
  107. <!-- 主体 侧边栏 -->
  108. <div
  109. v-if="sysName != '首页'"
  110. ref="aside"
  111. flex-box="0"
  112. :class="{'ibps-theme-container-aside': true, 'ibps-theme-container-transition': asideTransition}"
  113. :style="{width: asideCollapse ? asideWidthCollapse : asideWidth, opacity: searchActive ? 0.5 : 1}"
  114. >
  115. <!-- 侧部顶头栏-->
  116. <div class="layout-border-left">
  117. <div
  118. class="toggle-aside-btn"
  119. style="float: right; width: 25%;"
  120. @click="handleToggleAside"
  121. >
  122. <ibps-icon :name="asideCollapse ? 'indent' : 'outdent'" />
  123. </div>
  124. <div style="width: 74%;" class="toggle-aside-btn layout-border-left-name">
  125. <span>{{ getSystemName[0].name }}</span>
  126. </div>
  127. </div>
  128. <ibps-menu-side style="margin-top: 52px;" />
  129. </div>
  130. <!-- 主体 -->
  131. <div class="ibps-theme-container-main" flex-box="1" flex>
  132. <!-- 搜索 -->
  133. <transition name="fade-scale">
  134. <div
  135. v-show="searchActive"
  136. class="ibps-theme-container-main-layer"
  137. flex
  138. >
  139. <ibps-panel-search ref="panelSearch" @close="searchPanelClose"/>
  140. </div>
  141. </transition>
  142. <!-- 内容 -->
  143. <transition name="fade-scale">
  144. <div
  145. v-show="!searchActive"
  146. class="ibps-theme-container-main-layer"
  147. flex="dir:top"
  148. >
  149. <!-- tab -->
  150. <!-- <div class="ibps-theme-container-main-header" flex-box="0">
  151. <ibps-tabs />
  152. </div> -->
  153. <!-- 页面 -->
  154. <div class="ibps-theme-container-main-body" flex-box="1">
  155. <transition :name="transitionActive ? 'fade-transverse' : ''">
  156. <!-- <keep-alive :include="keepAlive"> -->
  157. <router-view :key="routerViewKey" />
  158. <!-- </keep-alive> -->
  159. </transition>
  160. </div>
  161. </div>
  162. </transition>
  163. </div>
  164. </div>
  165. </div>
  166. <!-- <FloatBall></FloatBall> -->
  167. </div>
  168. </template>
  169. <script>
  170. import IbpsLogo from './components/logo'
  171. import IbpsMenuSide from './components/menu-side/index.js'
  172. import IbpsMenuHeader from './components/menu-header/index.js'
  173. import IbpsTabs from './components/tabs'
  174. import IbpsHeaderSearch from './components/header-search'
  175. import FloatBall from './components/components/float-ball'
  176. import IbpsHeaderFullscreen from './components/header-fullscreen'
  177. // import IbpsHeaderLocking from './components/header-locking'
  178. // import IbpsHeaderLanguage from './components/header-language'
  179. // import IbpsHeaderSize from './components/header-size'
  180. // import IbpsHeaderTheme from './components/header-theme'
  181. // import IbpsHeaderToolbar from './components/header-toolbar'
  182. // import IbpsHeaderTenant from './components/header-tenant'
  183. import IbpsHeaderSetting from './components/header-setting'
  184. import IbpsHeaderMessage from './components/header-message'
  185. import panle from '@/components/jbd-panel'
  186. import IbpsHeaderUser from './components/header-user'
  187. import IbpsHeaderErrorLog from './components/header-error-log'
  188. import IbpsHeaderBaseUrl from './components/header-base-url'
  189. import IbpsHeaderCleanCache from './components/header-clean-cache'
  190. // import IbpsHeaderDownload from './components/header-download'
  191. // import IbpsNotifyMonitor from '@/business/platform/socket/notify-monitor'
  192. import { mapState, mapGetters, mapActions } from 'vuex'
  193. import mixinSearch from './mixins/search'
  194. import mixinLock from './mixins/lock'
  195. import setting from '@/setting.js'
  196. export default {
  197. name: 'ibps-layout-header-aside',
  198. components: {
  199. IbpsLogo,
  200. IbpsMenuSide,
  201. IbpsMenuHeader,
  202. IbpsTabs,
  203. IbpsHeaderSearch,
  204. FloatBall,
  205. panle,
  206. IbpsHeaderFullscreen,
  207. // IbpsHeaderLocking,
  208. // IbpsHeaderLanguage,
  209. // IbpsHeaderSize,
  210. // IbpsHeaderTheme,
  211. // IbpsHeaderToolbar,
  212. // IbpsHeaderTenant,
  213. IbpsHeaderSetting,
  214. IbpsHeaderMessage,
  215. IbpsHeaderUser,
  216. IbpsHeaderErrorLog,
  217. IbpsHeaderBaseUrl,
  218. IbpsHeaderCleanCache
  219. // IbpsHeaderDownload,
  220. // IbpsNotifyMonitor
  221. },
  222. mixins: [mixinSearch, mixinLock],
  223. data() {
  224. const {isSuper, account} = this.$store.getters
  225. return {
  226. // [侧边栏宽度] 正常状态
  227. asideWidth: '200px',
  228. // [侧边栏宽度] 折叠状态
  229. asideWidthCollapse: '65px',
  230. isSuper,
  231. account
  232. }
  233. },
  234. // watch: {
  235. // getSystemName(value) {
  236. // this.sysName = ''
  237. // }
  238. // },
  239. mounted() {
  240. // window.performance.navigation.type === 1
  241. if (this.$route.name === 'dashboard') {
  242. this.sysName = '首页'
  243. }
  244. },
  245. computed: {
  246. ...mapState('ibps', {
  247. // sysName:state=>state.menu.sysName,
  248. keepAlive: state => state.page.keepAlive,
  249. grayActive: state => state.gray.active,
  250. transitionActive: state => state.transition.active,
  251. asideCollapse: state => state.menu.asideCollapse,
  252. asideTransition: state => state.menu.asideTransition,
  253. system: state => state.system.system,
  254. subsystemList: state => state.system.subsystemList
  255. }),
  256. ...mapGetters('ibps', {
  257. themeActiveSetting: 'theme/activeSetting'
  258. }),
  259. getSystemName() {
  260. return this.header().filter(name => { return name.id === this.activeHeader() })
  261. },
  262. /**
  263. * @description 用来实现带参路由的缓存
  264. */
  265. sysName: {
  266. get() {
  267. if (this.$route.name === 'dashboard') {
  268. return '首页'
  269. } else {
  270. return ''
  271. }
  272. },
  273. set() {
  274. if (this.$route.name === 'dashboard') {
  275. return '首页'
  276. } else {
  277. return ''
  278. }
  279. }
  280. },
  281. routerViewKey() {
  282. // 默认情况下 key 类似 __transition-n-/foo
  283. // 这里的字符串操作是为了最终 key 的格式和原来相同 类似 __transition-n-__stamp-time-/foo
  284. const stamp = this.$route.meta[`__stamp-${this.$route.path}`] || ''
  285. return `${stamp ? `__stamp-${stamp}-` : ''}${this.$route.path}`
  286. },
  287. /**
  288. * @description 最外层容器的背景图片样式
  289. */
  290. styleLayoutMainGroup() {
  291. return { ...(this.themeActiveSetting.backgroundImage ? {backgroundImage: `url('${this.$baseUrl}${this.themeActiveSetting.backgroundImage}')`} : {})}
  292. },
  293. logoIconAll() {
  294. return `${this.$baseUrl}images/theme/${this.themeActiveSetting.name}/all.png`
  295. },
  296. logoIconOnly() {
  297. return `${this.$baseUrl}images/theme/${this.themeActiveSetting.name}/only.png`
  298. }
  299. },
  300. methods: {
  301. ...mapActions('ibps/menu', ['asideCollapseToggle']),
  302. ...mapState('ibps/menu', ['activeHeader', 'header', 'activeName']),
  303. /* 跳转首页*/
  304. goToMain() {
  305. // this.sysName = "首页"
  306. this.$router.push({
  307. name: 'dashboard'
  308. })
  309. },
  310. pageChange() {
  311. this.sysName = ''
  312. },
  313. /**
  314. * 接收点击切换侧边栏的按钮
  315. */
  316. handleToggleAside() {
  317. this.asideCollapseToggle()
  318. },
  319. handleSubsystemClick(system) {
  320. this.$store.dispatch('ibps/system/set', system)
  321. window.location.href = this.$baseUrl
  322. // location.reload() // 为了重新实例化vue-router对象 避免bug
  323. }
  324. }
  325. }
  326. </script>
  327. <style lang="scss">
  328. // 注册主题
  329. @import '~@/assets/styles/theme/register.scss';
  330. .jbd-sys-title {
  331. background: linear-gradient(to top, rgb(48, 194, 189), rgb(145, 216, 210));
  332. // background: rgb(51, 150, 209);
  333. height: 40px;
  334. line-height: 40px;
  335. font-size: 18px;
  336. color: #fff;
  337. text-align: center;
  338. }
  339. .jbd-sys-title-cont {
  340. height: 40px;
  341. line-height: 40px;
  342. font-weight: bold;
  343. font-size: 14px;
  344. }
  345. .jbd-sys-title-contact {
  346. line-height: 20px;
  347. margin-right: 40px;
  348. font-size: 14px;
  349. }
  350. .layout-border-left {
  351. float: left;
  352. box-shadow: 0px 2px 4px #e78c45, 0 0 5px rgba(155, 155, 0, 0.04);
  353. width: 100%;
  354. height: 50px;
  355. line-height: 50px;
  356. .layout-border-left-name {
  357. float: left;
  358. font-size: 18px;
  359. font-weight: bold;
  360. }
  361. }
  362. </style>