layout.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  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="https://www.szjyxt.com/#/fileView?url=https%3A%2F%2Fwww.szjyxt.com%2Fibps%2Fplatform%2Fv3%2Ffile%2Fdownload%3FattachmentId%3D925044155762081792&isEdit=true&fileType=docx&title=GDYR-CX01-A0%20%E4%BF%9D%E8%AF%81%E5%85%AC%E6%AD%A3%E6%80%A7%E7%AE%A1%E7%90%86%E7%A8%8B%E5%BA%8F&user=%5Bobject%20Object%5D&mode=view&editUrl=https%3A%2F%2Fwww.szjyxt.com%2Fibps%2Fplatform%2Fv3%2Ffile%2FeditCallback%3FfileName%3DGDYR-CX01-A0%20%E4%BF%9D%E8%AF%81%E5%85%AC%E6%AD%A3%E6%80%A7%E7%AE%A1%E7%90%86%E7%A8%8B%E5%BA%8F%26fileType%3Ddocx&key="
  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. <span style="font-size: 12px; cursor: pointer;" @click="goToMain()">首页</span>
  92. <span style="margin: 0 10px;">|</span>
  93. <ibps-header-message />
  94. <!-- 消息中心 -->
  95. <span style="margin: 0 10px;">|</span>
  96. <ibps-header-user style="margin-right: 15px;"/>
  97. <!-- <span style="margin-left: 10px;">|</span>
  98. <ibps-header-setting /> -->
  99. </div>
  100. </div>
  101. <!-- 下面 主体 -->
  102. <div class="ibps-theme-container" flex-box="1" flex>
  103. <!-- 主体 侧边栏 -->
  104. <div
  105. v-if="sysName != '首页'"
  106. ref="aside"
  107. flex-box="0"
  108. :class="{'ibps-theme-container-aside': true, 'ibps-theme-container-transition': asideTransition}"
  109. :style="{width: asideCollapse ? asideWidthCollapse : asideWidth, opacity: searchActive ? 0.5 : 1}"
  110. >
  111. <!-- 侧部顶头栏-->
  112. <div class="layout-border-left">
  113. <div
  114. class="toggle-aside-btn"
  115. style="float: right; width: 25%;"
  116. @click="handleToggleAside"
  117. >
  118. <ibps-icon :name="asideCollapse ? 'indent' : 'outdent'" />
  119. </div>
  120. <div style="width: 74%;" class="toggle-aside-btn layout-border-left-name">
  121. <span>{{ getSystemName[0].name }}</span>
  122. </div>
  123. </div>
  124. <ibps-menu-side style="margin-top: 52px;" />
  125. </div>
  126. <!-- 主体 -->
  127. <div class="ibps-theme-container-main" flex-box="1" flex>
  128. <!-- 搜索 -->
  129. <transition name="fade-scale">
  130. <div
  131. v-show="searchActive"
  132. class="ibps-theme-container-main-layer"
  133. flex
  134. >
  135. <ibps-panel-search ref="panelSearch" @close="searchPanelClose"/>
  136. </div>
  137. </transition>
  138. <!-- 内容 -->
  139. <transition name="fade-scale">
  140. <div
  141. v-show="!searchActive"
  142. class="ibps-theme-container-main-layer"
  143. flex="dir:top"
  144. >
  145. <!-- tab -->
  146. <!-- <div class="ibps-theme-container-main-header" flex-box="0">
  147. <ibps-tabs />
  148. </div> -->
  149. <!-- 页面 -->
  150. <div class="ibps-theme-container-main-body" flex-box="1">
  151. <transition :name="transitionActive ? 'fade-transverse' : ''">
  152. <!-- <keep-alive :include="keepAlive"> -->
  153. <router-view :key="routerViewKey" />
  154. <!-- </keep-alive> -->
  155. </transition>
  156. </div>
  157. </div>
  158. </transition>
  159. </div>
  160. </div>
  161. </div>
  162. <!-- <FloatBall></FloatBall> -->
  163. </div>
  164. </template>
  165. <script>
  166. import IbpsLogo from './components/logo'
  167. import IbpsMenuSide from './components/menu-side/index.js'
  168. import IbpsMenuHeader from './components/menu-header/index.js'
  169. import IbpsTabs from './components/tabs'
  170. import IbpsHeaderSearch from './components/header-search'
  171. import FloatBall from './components/components/float-ball'
  172. import IbpsHeaderFullscreen from './components/header-fullscreen'
  173. // import IbpsHeaderLocking from './components/header-locking'
  174. // import IbpsHeaderLanguage from './components/header-language'
  175. // import IbpsHeaderSize from './components/header-size'
  176. // import IbpsHeaderTheme from './components/header-theme'
  177. // import IbpsHeaderToolbar from './components/header-toolbar'
  178. // import IbpsHeaderTenant from './components/header-tenant'
  179. import IbpsHeaderSetting from './components/header-setting'
  180. import IbpsHeaderMessage from './components/header-message'
  181. import panle from '@/components/jbd-panel'
  182. import IbpsHeaderUser from './components/header-user'
  183. import IbpsHeaderErrorLog from './components/header-error-log'
  184. import IbpsHeaderBaseUrl from './components/header-base-url'
  185. // import IbpsHeaderDownload from './components/header-download'
  186. // import IbpsNotifyMonitor from '@/business/platform/socket/notify-monitor'
  187. import { mapState, mapGetters, mapActions } from 'vuex'
  188. import mixinSearch from './mixins/search'
  189. import mixinLock from './mixins/lock'
  190. import setting from '@/setting.js'
  191. export default {
  192. name: 'ibps-layout-header-aside',
  193. components: {
  194. IbpsLogo,
  195. IbpsMenuSide,
  196. IbpsMenuHeader,
  197. IbpsTabs,
  198. IbpsHeaderSearch,
  199. FloatBall,
  200. panle,
  201. IbpsHeaderFullscreen,
  202. // IbpsHeaderLocking,
  203. // IbpsHeaderLanguage,
  204. // IbpsHeaderSize,
  205. // IbpsHeaderTheme,
  206. // IbpsHeaderToolbar,
  207. // IbpsHeaderTenant,
  208. IbpsHeaderSetting,
  209. IbpsHeaderMessage,
  210. IbpsHeaderUser,
  211. IbpsHeaderErrorLog,
  212. IbpsHeaderBaseUrl
  213. // IbpsHeaderDownload,
  214. // IbpsNotifyMonitor
  215. },
  216. mixins: [mixinSearch, mixinLock],
  217. data() {
  218. return {
  219. // [侧边栏宽度] 正常状态
  220. asideWidth: '200px',
  221. // [侧边栏宽度] 折叠状态
  222. asideWidthCollapse: '65px'
  223. }
  224. },
  225. // watch: {
  226. // getSystemName(value) {
  227. // this.sysName = ''
  228. // }
  229. // },
  230. mounted() {
  231. // window.performance.navigation.type == 1
  232. if (this.$route.name == 'dashboard') {
  233. this.sysName = '首页'
  234. }
  235. },
  236. computed: {
  237. ...mapState('ibps', {
  238. // sysName:state=>state.menu.sysName,
  239. keepAlive: state => state.page.keepAlive,
  240. grayActive: state => state.gray.active,
  241. transitionActive: state => state.transition.active,
  242. asideCollapse: state => state.menu.asideCollapse,
  243. asideTransition: state => state.menu.asideTransition,
  244. system: state => state.system.system,
  245. subsystemList: state => state.system.subsystemList
  246. }),
  247. ...mapGetters('ibps', {
  248. themeActiveSetting: 'theme/activeSetting'
  249. }),
  250. getSystemName() {
  251. return this.header().filter(name => { return name.id == this.activeHeader() })
  252. },
  253. /**
  254. * @description 用来实现带参路由的缓存
  255. */
  256. sysName: {
  257. get() {
  258. if (this.$route.name == 'dashboard') {
  259. return '首页'
  260. } else {
  261. return ''
  262. }
  263. },
  264. set() {
  265. if (this.$route.name == 'dashboard') {
  266. return '首页'
  267. } else {
  268. return ''
  269. }
  270. }
  271. },
  272. routerViewKey() {
  273. // 默认情况下 key 类似 __transition-n-/foo
  274. // 这里的字符串操作是为了最终 key 的格式和原来相同 类似 __transition-n-__stamp-time-/foo
  275. const stamp = this.$route.meta[`__stamp-${this.$route.path}`] || ''
  276. return `${stamp ? `__stamp-${stamp}-` : ''}${this.$route.path}`
  277. },
  278. /**
  279. * @description 最外层容器的背景图片样式
  280. */
  281. styleLayoutMainGroup() {
  282. return { ...(this.themeActiveSetting.backgroundImage ? {backgroundImage: `url('${this.$baseUrl}${this.themeActiveSetting.backgroundImage}')`} : {})}
  283. },
  284. logoIconAll() {
  285. return `${this.$baseUrl}images/theme/${this.themeActiveSetting.name}/all.png`
  286. },
  287. logoIconOnly() {
  288. return `${this.$baseUrl}images/theme/${this.themeActiveSetting.name}/only.png`
  289. }
  290. },
  291. methods: {
  292. ...mapActions('ibps/menu', ['asideCollapseToggle']),
  293. ...mapState('ibps/menu', ['activeHeader', 'header', 'activeName']),
  294. /* 跳转首页*/
  295. goToMain() {
  296. // this.sysName = "首页"
  297. this.$router.push({
  298. name: 'dashboard'
  299. })
  300. },
  301. pageChange() {
  302. this.sysName = ''
  303. },
  304. /**
  305. * 接收点击切换侧边栏的按钮
  306. */
  307. handleToggleAside() {
  308. this.asideCollapseToggle()
  309. },
  310. handleSubsystemClick(system) {
  311. this.$store.dispatch('ibps/system/set', system)
  312. window.location.href = this.$baseUrl
  313. // location.reload() // 为了重新实例化vue-router对象 避免bug
  314. }
  315. }
  316. }
  317. </script>
  318. <style lang="scss">
  319. // 注册主题
  320. @import '~@/assets/styles/theme/register.scss';
  321. .jbd-sys-title {
  322. background: linear-gradient(to top, rgb(48, 194, 189), rgb(145, 216, 210));
  323. // background: rgb(51, 150, 209);
  324. height: 40px;
  325. line-height: 40px;
  326. font-size: 18px;
  327. color: #fff;
  328. text-align: center;
  329. }
  330. .jbd-sys-title-cont {
  331. height: 40px;
  332. line-height: 40px;
  333. font-weight: bold;
  334. font-size: 14px;
  335. }
  336. .jbd-sys-title-contact {
  337. line-height: 20px;
  338. margin-right: 40px;
  339. font-size: 14px;
  340. }
  341. .layout-border-left {
  342. float: left;
  343. box-shadow: 0px 2px 4px #e78c45, 0 0 5px rgba(155, 155, 0, 0.04);
  344. width: 100%;
  345. height: 50px;
  346. line-height: 50px;
  347. .layout-border-left-name {
  348. float: left;
  349. font-size: 18px;
  350. font-weight: bold;
  351. }
  352. }
  353. </style>