Navbar.vue 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886
  1. <template>
  2. <div>
  3. <div class="navbar">
  4. <!-- 菜单展开缩起 -->
  5. <hamburger :is-active="sidebar.opened" class="hamburger-container" @toggleClick="toggleSideBar" />
  6. <div class="menu_module">
  7. <div class="menu_module_view">
  8. <v-scroll-view
  9. :x="true"
  10. :y="false"
  11. slidingBgClassName="slidingBgClassName"
  12. slidingBlockClassName="slidingBlockClassName"
  13. >
  14. <div class="menu_module_fj">
  15. <div
  16. v-for="(item, index) in routes"
  17. :key="index"
  18. :class="{ item: true, select: path === item.path }"
  19. @click="tizhuanyemian(item)"
  20. >
  21. {{ item.meta.title }}
  22. </div>
  23. </div>
  24. </v-scroll-view>
  25. </div>
  26. </div>
  27. <!-- 右侧 -->
  28. <div class="right-menu">
  29. <div class="right-menu-item" v-if="bigViewsBool" @click="goBigViews">
  30. <el-button size="mini">数据大屏</el-button>
  31. </div>
  32. <div class="right-menu-item">
  33. <el-autocomplete
  34. v-model="pathurl"
  35. :fetch-suggestions="querySearchAsync"
  36. s
  37. placeholder="搜索菜单"
  38. @select="handleSelect"
  39. ></el-autocomplete>
  40. </div>
  41. <div
  42. style="margin-right: 20px; cursor: pointer"
  43. @click="
  44. getList()
  45. isShow = true
  46. "
  47. >
  48. <i class="el-icon-message-solid"></i>
  49. <el-badge :is-dot="isDot1 || isDot2"></el-badge>
  50. </div>
  51. <shortcut />
  52. <template v-if="device !== 'mobile'">
  53. <!-- 全屏控制 -->
  54. <screenfull id="screenfull" class="right-menu-item hover-effect" />
  55. </template>
  56. <el-dropdown class="user-container" trigger="click">
  57. <div class="user right-menu-item hover-effect">
  58. <div class="flex">
  59. {{ Vue_Translation_Of_Text_Type }}
  60. </div>
  61. </div>
  62. <el-dropdown-menu slot="dropdown" class="user-dropdown">
  63. <el-dropdown-item divided @click.native="$setLanguage('zh')">
  64. <span style="display: block">中文</span>
  65. </el-dropdown-item>
  66. <el-dropdown-item divided @click.native="$setLanguage('ru')">
  67. <span style="display: block">俄文</span>
  68. </el-dropdown-item>
  69. <el-dropdown-item divided @click.native="$setLanguage('en')">
  70. <span style="display: block">英文</span>
  71. </el-dropdown-item>
  72. <el-dropdown-item divided @click.native="$setLanguage('ja')">
  73. <span style="display: block">日文</span>
  74. </el-dropdown-item>
  75. <el-dropdown-item divided @click.native="$setLanguage('ar')">
  76. <span style="display: block">阿拉伯文</span>
  77. </el-dropdown-item>
  78. <el-dropdown-item divided @click.native="$setLanguage('tr')">
  79. <span style="display: block">土耳其</span>
  80. </el-dropdown-item>
  81. </el-dropdown-menu>
  82. </el-dropdown>
  83. <el-dropdown class="user-container" trigger="click">
  84. <div class="user right-menu-item hover-effect">
  85. <div class="flex">
  86. <i class="el-icon-user-solid" />
  87. <span :class="name.length > 5 ? 'ellipsis' : ''">{{ name }}</span>
  88. </div>
  89. </div>
  90. <el-dropdown-menu slot="dropdown" class="user-dropdown">
  91. <router-link :to="{ name: 'profile' }">
  92. <el-dropdown-item>个人信息</el-dropdown-item>
  93. </router-link>
  94. <el-dropdown-item divided @click.native="logout">
  95. <span style="display: block">退出登录</span>
  96. </el-dropdown-item>
  97. </el-dropdown-menu>
  98. </el-dropdown>
  99. </div>
  100. </div>
  101. <notice-bar />
  102. <el-drawer
  103. title="系统消息"
  104. :visible.sync="isShow"
  105. :append-to-body="true"
  106. :with-header="false"
  107. direction="rtl"
  108. size="25%"
  109. >
  110. <div class="message">
  111. <div class="head">
  112. <div class="flex_asb">
  113. <el-radio-group size="small" v-model="messageType" @change="getList">
  114. <el-badge :is-dot="isDot1" class="item">
  115. <el-radio-button
  116. :label="[
  117. 'WBI',
  118. 'WBK',
  119. 'CRE_ORDER',
  120. 'SEND_MALL',
  121. 'RP_MALL',
  122. 'CR_SALES',
  123. 'ENGIN_PAY_ORDER',
  124. 'CR_ES_SALES'
  125. ]"
  126. >系统消息</el-radio-button
  127. >
  128. </el-badge>
  129. <el-badge :is-dot="isDot2" class="item">
  130. <el-radio-button :label="['NOTICE']">平台公告</el-radio-button>
  131. </el-badge>
  132. </el-radio-group>
  133. <el-switch
  134. v-model="isOpen"
  135. @change="updateIsNotice"
  136. inactive-text="消息弹窗"
  137. active-color="#13ce66"
  138. inactive-color="#ff4949"
  139. >
  140. </el-switch>
  141. </div>
  142. <el-radio-group size="mini" v-model="dateType" @change="getList" style="margin: 10px 0">
  143. <el-radio-button label="">全部</el-radio-button>
  144. <el-radio-button :label="0">今天</el-radio-button>
  145. <el-radio-button :label="1">昨天</el-radio-button>
  146. <el-radio-button :label="6">近7天</el-radio-button>
  147. <el-radio-button :label="29">近30天</el-radio-button>
  148. </el-radio-group>
  149. <div class="flex_asb">
  150. <el-radio-group size="mini" v-model="readFlag" @change="getList">
  151. <el-radio-button label="">全部</el-radio-button>
  152. <el-badge :hidden="count > 0 ? false : true" :value="count" class="item" style="margin: 0 10px">
  153. <el-radio-button label="NO">未读</el-radio-button>
  154. </el-badge>
  155. <el-badge :value="count" :hidden="true" class="item">
  156. <el-radio-button label="YES">已读</el-radio-button>
  157. </el-badge>
  158. </el-radio-group>
  159. <div style="color: #409eff; cursor: pointer" @click="confirmRead">
  160. <i class="el-icon-message-solid"></i>
  161. <span style="font-size: 14px">全部已读</span>
  162. </div>
  163. </div>
  164. </div>
  165. <el-card class="box-card" v-for="(item, index) in messageData" style="margin-top: 10px">
  166. <div
  167. @click="
  168. isShow = false
  169. toDetail(
  170. item.adminNoticeType,
  171. item.paidType,
  172. item.adminNoticeType == 'NOTICE' ? item.noticeId : item.orderId,
  173. item.id
  174. )
  175. "
  176. >
  177. <div v-if="item.adminNoticeType == 'NOTICE'">
  178. <div class="flex_asb item">
  179. <div>
  180. <span>公告类型:</span>
  181. <span>{{ statusFilter(item.adminNoticeType) }}</span>
  182. </div>
  183. <div class="read1" v-if="item.readFlag == 'NO'">未读</div>
  184. <div class="read2" v-if="item.readFlag == 'YES'">已读</div>
  185. </div>
  186. <div class="item">
  187. <div>
  188. <span>文件标题:</span>
  189. <span style="color: #409eff">{{ item.title }}</span>
  190. </div>
  191. </div>
  192. <div class="item">
  193. <div>
  194. <span>发布人:</span>
  195. <span>{{ item.issueNickName | '' }}</span>
  196. </div>
  197. </div>
  198. <div class="item">
  199. <div>
  200. <span>发布时间:</span>
  201. <span>{{ item.issueTime }}</span>
  202. </div>
  203. </div>
  204. <div v-if="item.readFlag == 'YES'" class="item">
  205. <span>阅读人:</span>
  206. <span>{{ item.adminNickName }} {{ item.readTime }}</span>
  207. </div>
  208. </div>
  209. <div v-else>
  210. <div class="flex_asb item">
  211. <div>
  212. <span>消息类型:</span>
  213. <span>{{ statusFilter(item.adminNoticeType) }}</span>
  214. </div>
  215. <div class="read1" v-if="item.readFlag == 'NO'">未读</div>
  216. <div class="read2" v-if="item.readFlag == 'YES'">已读</div>
  217. </div>
  218. <div class="item">
  219. <div>
  220. <span>订单编号:</span>
  221. <span style="color: #409eff">{{ item.orderId }}</span>
  222. </div>
  223. </div>
  224. <div class="item">
  225. <div>
  226. <span>消息内容:</span>
  227. <span>{{ item.content }}</span>
  228. </div>
  229. </div>
  230. <div class="item">
  231. <div>
  232. <span>创建时间:</span>
  233. <span>{{ item.createTime }}</span>
  234. </div>
  235. </div>
  236. <div v-if="item.readFlag == 'YES'" class="item">
  237. <span>阅读人:</span>
  238. <span>{{ item.adminNickName }} {{ item.readTime }}</span>
  239. </div>
  240. </div>
  241. </div>
  242. </el-card>
  243. <el-empty v-if="messageData.length == 0" description="暂无数据"></el-empty>
  244. <div class="flex_ac bottom">
  245. <el-pagination
  246. @current-change="handleCurrentChange"
  247. :current-page="currentPage"
  248. :page-size="pageSize"
  249. layout="prev, pager, next"
  250. background
  251. :total="listTotal"
  252. ></el-pagination>
  253. </div>
  254. </div>
  255. </el-drawer>
  256. </div>
  257. </template>
  258. <script>
  259. import { mapGetters } from 'vuex'
  260. import Hamburger from '@/components/Hamburger'
  261. import Shortcut from '@/components/Shortcut'
  262. import Screenfull from '@/components/Screenfull'
  263. import NavMenu from '@/components/NavMenu'
  264. import vScrollView from 'v-scroll-view'
  265. import NoticeBar from '@/components/NoticeBar'
  266. import { pages } from '@/settings'
  267. import request from '@/utils/request'
  268. function getc(obj) {
  269. if (!obj.children || !obj.children.length) {
  270. return obj
  271. } else {
  272. return getc(obj.children[0])
  273. }
  274. }
  275. export default {
  276. components: {
  277. NoticeBar,
  278. Hamburger,
  279. Screenfull,
  280. NavMenu,
  281. Shortcut,
  282. vScrollView
  283. },
  284. data() {
  285. return {
  286. Vue_Translation_Of_Text_Type: window?.Vue_Translation_Of_Text_Type || 'zh',
  287. pathurl: '',
  288. visible: false,
  289. noticeCount: 0,
  290. path: `/${this.$route.path.split('/')[1] || ''}`,
  291. isShow: false,
  292. isOpen: true,
  293. checked: false,
  294. messageType: ['WBI', 'WBK', 'CRE_ORDER', 'SEND_MALL', 'RP_MALL', 'CR_SALES', 'ENGIN_PAY_ORDER', 'CR_ES_SALES'],
  295. messageData: [],
  296. dateType: '',
  297. readFlag: '',
  298. timer: null,
  299. listTotal: 0,
  300. currentPage: 1, // 当前页码
  301. pageSize: 10, // 每页数量
  302. count: 0,
  303. isDot1: false,
  304. isDot2: false
  305. }
  306. },
  307. computed: {
  308. routes() {
  309. return global.antRouter.filter(item => item.meta)
  310. },
  311. bigViewsBool() {
  312. return !!global.antRouter.find(item => item.code == 'bigViews')
  313. },
  314. noticeVisible() {
  315. return this.noticeCount > 0
  316. },
  317. ...mapGetters(['userid']),
  318. ...mapGetters(['sidebar', 'avatar', 'device', 'name', 'isNotice']),
  319. filterTime() {
  320. if (this.dateType === '') {
  321. return ['', '']
  322. } else {
  323. var date = new Date()
  324. var base = Date.parse(date) // 转换为时间戳
  325. var year = date.getFullYear() //获取当前年份
  326. var mon = date.getMonth() + 1 //获取当前月份
  327. var day = date.getDate() //获取当前日
  328. var oneDay = 24 * 3600 * 1000
  329. var daytimeArr = []
  330. var now = new Date(base - oneDay * this.dateType)
  331. var myear = now.getFullYear()
  332. var month = now.getMonth() + 1
  333. var mday = now.getDate()
  334. if (this.dateType == 1) {
  335. return [
  336. `${myear}-${month > 9 ? month : '0' + month}-${mday > 9 ? mday : '0' + mday} 00:00:00`,
  337. `${myear}-${month > 9 ? month : '0' + month}-${mday > 9 ? mday : '0' + mday} 23:59:59`
  338. ]
  339. } else {
  340. return [
  341. `${myear}-${month > 9 ? month : '0' + month}-${mday > 9 ? mday : '0' + mday} 00:00:00`,
  342. `${year}-${mon > 9 ? mon : '0' + mon}-${day > 9 ? day : '0' + day} 23:59:59`
  343. ]
  344. }
  345. }
  346. },
  347. statusFilter() {
  348. return function (val) {
  349. const MAP = {
  350. NOTICE: '平台公告',
  351. WBI: '维保消息费用申请',
  352. WBK: '维保费用申请审批',
  353. CRE_ORDER: '创建工单',
  354. SEND_MALL: '商城订单发货',
  355. RP_MALL: '商城订单维权',
  356. CR_SALES: '订单支付成功',
  357. ENGIN_PAY_ORDER: '工程收款单',
  358. CR_ES_SALES: '二手商品订单'
  359. }
  360. return MAP[val]
  361. }
  362. },
  363. typeFilter() {
  364. return function (val, paidType) {
  365. const MAP = {
  366. NOTICE: 'systemMessage',
  367. WBI: 'applicationWithoutFee',
  368. WBK: 'applicationWithoutFee',
  369. CRE_ORDER: 'workOrderPool',
  370. SEND_MALL: 'order_detail',
  371. RP_MALL: 'order_refund_detail',
  372. CR_SALES:
  373. paidType == 'M'
  374. ? 'auxiliarySalesOrder'
  375. : paidType == 'P'
  376. ? 'attachmentSalesOrder'
  377. : paidType == 'YB'
  378. ? 'orderSettleManag'
  379. : paidType == 'MALL'
  380. ? 'order_detail'
  381. : '',
  382. ENGIN_PAY_ORDER: 'projectCollectionManagement',
  383. CR_ES_SALES: 'orderManagement'
  384. }
  385. return MAP[val]
  386. }
  387. }
  388. },
  389. watch: {
  390. $route() {
  391. this.path = `/${this.$route.path.split('/')[1] || ''}`
  392. },
  393. path(newVal) {
  394. this.$store.commit('app/SET_L1_PATH', newVal)
  395. if (
  396. !~this.$route.path
  397. .split('/')
  398. .map(str => `/${str}`)
  399. .indexOf(newVal)
  400. ) {
  401. var item = getc(this.routes.find(item => item.path === newVal))
  402. if (item) {
  403. this.$router.push(item.path)
  404. }
  405. }
  406. }
  407. },
  408. created() {
  409. clearInterval(this.timer)
  410. this.getUserInfo()
  411. this.redDot()
  412. },
  413. mounted() {
  414. this.$store.commit('app/SET_L1_PATH', this.path)
  415. },
  416. methods: {
  417. tizhuanyemian(item) {
  418. if (item.type == 4) {
  419. this.$router.push({ name: item.name })
  420. } else {
  421. this.path = item.path
  422. }
  423. },
  424. goBigViews() {
  425. this.$router.push({
  426. name: 'bigViews'
  427. })
  428. },
  429. querySearchAsync(queryString, cb) {
  430. var data = pages.filter(
  431. item =>
  432. !~item.path.indexOf(':pageName?/:pageType?/:pageCode?/:pagePam?') && !!~item.meta.title.indexOf(queryString)
  433. )
  434. cb(
  435. data.map(item => ({
  436. value: item.meta.title,
  437. path: item.path
  438. }))
  439. )
  440. },
  441. handleSelect(item) {
  442. if (item.path) {
  443. this.$router.push({
  444. path: item.path
  445. })
  446. }
  447. this.pathurl = ''
  448. },
  449. async logout() {
  450. await this.$store.dispatch('user/logout')
  451. this.$store.commit('tagsView/SET_RESET_VIES')
  452. this.$router.push(`/login`)
  453. },
  454. toggleSideBar() {
  455. this.$store.dispatch('app/toggleSideBar')
  456. },
  457. //获取最新消息并弹窗
  458. getMessageTips() {
  459. const that = this
  460. this.timer = setInterval(() => {
  461. request({
  462. url: `/notice/list/out`,
  463. method: 'get',
  464. params: {
  465. num: 30
  466. }
  467. }).then(res => {
  468. res.data.forEach(item => {
  469. this.$notify({
  470. title: '新消息',
  471. position: 'bottom-right',
  472. duration: 30000,
  473. message: that.$createElement(
  474. 'div',
  475. {
  476. style: 'cursor: pointer;text-align: left;',
  477. on: {
  478. click: that.toDetail.bind(
  479. that,
  480. item.adminNoticeType,
  481. item.paidType,
  482. item.adminNoticeType == 'NOTICE' ? item.noticeId : item.orderId,
  483. item.id
  484. )
  485. }
  486. },
  487. [
  488. that.$createElement('span', null, that.statusFilter(item.adminNoticeType) + ' '),
  489. that.$createElement(
  490. 'span',
  491. {
  492. style: 'color: #409EFF;'
  493. },
  494. ' ' + item.adminNoticeType == 'NOTICE' ? item.title : item.orderId
  495. ),
  496. that.$createElement('span', null, item.adminNoticeType == 'NOTICE' ? '' : item.content)
  497. // that.$createElement(
  498. // "el-checkbox",
  499. // {
  500. // on: {
  501. // change: that.updateIsNotice.bind(that)
  502. // },
  503. // }, '不再弹窗新消息'
  504. // )
  505. ]
  506. )
  507. })
  508. })
  509. })
  510. }, 30000)
  511. },
  512. getCount() {
  513. request({
  514. url: `/notice/list/count`,
  515. method: 'get',
  516. params: {
  517. noticeType: this.messageType.join(','),
  518. readFlag: 'NO'
  519. }
  520. }).then(res => {
  521. this.count = res.data
  522. })
  523. },
  524. redDot() {
  525. request({
  526. url: `/notice/list/count`,
  527. method: 'get',
  528. params: {
  529. noticeType: ['WBI', 'WBK', 'CRE_ORDER', 'SEND_MALL', 'RP_MALL', 'CR_SALES'].join(','),
  530. readFlag: 'NO'
  531. }
  532. }).then(res => {
  533. this.isDot1 = res.data > 0 ? true : false
  534. })
  535. request({
  536. url: `/notice/list/count`,
  537. method: 'get',
  538. params: {
  539. noticeType: ['NOTICE'].join(','),
  540. readFlag: 'NO'
  541. }
  542. }).then(res => {
  543. this.isDot2 = res.data > 0 ? true : false
  544. })
  545. },
  546. getUserInfo() {
  547. const that = this
  548. request({
  549. url: `/admin/user/detail`,
  550. method: 'get',
  551. params: {
  552. adminUserId: this.userid
  553. }
  554. }).then(res => {
  555. this.isOpen = res.data.isNotice == 'YES' ? true : false
  556. if (res.data.isNotice == 'NO') {
  557. clearInterval(this.timer)
  558. } else {
  559. clearInterval(this.timer)
  560. this.getMessageTips()
  561. }
  562. })
  563. },
  564. //全部已读
  565. confirmRead() {
  566. this.$confirm('是否全部设为已读, 是否继续?', '提示', {
  567. confirmButtonText: '确定',
  568. cancelButtonText: '取消',
  569. type: 'warning'
  570. })
  571. .then(() => {
  572. request({
  573. url: `/notice/mark/read/all`,
  574. method: 'post',
  575. data: {}
  576. }).then(res => {
  577. if (res.code == 200) {
  578. this.getList()
  579. this.$message.success('全部已读成功!')
  580. }
  581. })
  582. })
  583. .catch(() => {
  584. this.$message({
  585. type: 'info',
  586. message: '已取消'
  587. })
  588. })
  589. },
  590. //点击不再弹窗新消息
  591. updateIsNotice(e) {
  592. request({
  593. url: `/notice/updateIsNotice`,
  594. method: 'post',
  595. params: {
  596. isNotice: e ? 'YES' : 'NO'
  597. }
  598. }).then(res => {
  599. if (res.code == 200) {
  600. this.getUserInfo()
  601. this.$message.success(e ? '已开启弹窗消息提醒' : '已关闭弹窗消息提醒')
  602. if (!e) {
  603. clearInterval(this.timer)
  604. }
  605. }
  606. })
  607. },
  608. getList() {
  609. request({
  610. url: `/notice/list`,
  611. method: 'post',
  612. data: {
  613. pageNum: this.currentPage,
  614. pageSize: this.pageSize,
  615. params: [
  616. { param: 'nr.read_flag', compare: '=', value: this.readFlag },
  617. { param: 'nr.admin_notice_type', compare: '=', value: this.messageType },
  618. { param: 'nr.issue_time', compare: '>=', value: this.filterTime[0] },
  619. { param: 'nr.issue_time', compare: '<=', value: this.filterTime[1] }
  620. ]
  621. }
  622. }).then(res => {
  623. this.getCount()
  624. this.redDot()
  625. this.listTotal = res.data.total
  626. this.messageData = res.data.records
  627. })
  628. },
  629. // 更改当前页
  630. handleCurrentChange(val) {
  631. this.currentPage = val
  632. this.getList()
  633. },
  634. toDetail(type, paidType, orderId, id) {
  635. console.log(this.typeFilter(type, paidType))
  636. this.read(id)
  637. this.$router.push({
  638. name: this.typeFilter(type, paidType),
  639. params: {
  640. pageName: orderId,
  641. pageType: 'detail',
  642. pageCode: orderId
  643. },
  644. query: {
  645. id: orderId,
  646. orderId: orderId
  647. }
  648. })
  649. },
  650. read(id) {
  651. request({
  652. url: `/notice/mark/read`,
  653. method: 'post',
  654. params: {
  655. noticeIds: id
  656. }
  657. }).then(res => {})
  658. }
  659. }
  660. }
  661. </script>
  662. <style lang="scss" scoped>
  663. @import '~@/styles/variables.scss';
  664. // ::v-deep .el-drawer__container{
  665. // top: 50px;
  666. // }
  667. ::v-deep .is-fixed {
  668. right: 10px !important;
  669. }
  670. ::v-deep .slidingBgClassName {
  671. background: rgba(0, 0, 0, 0.01) !important;
  672. }
  673. ::v-deep .slidingBlockClassName {
  674. background: rgba(0, 0, 0, 0.05) !important;
  675. }
  676. .flex_asb {
  677. display: flex;
  678. justify-content: space-between;
  679. align-items: center;
  680. }
  681. .flex_ac {
  682. display: flex;
  683. justify-content: center;
  684. }
  685. .message {
  686. padding: 20px;
  687. position: relative;
  688. min-height: 100%;
  689. padding-bottom: 60px;
  690. padding-top: 150px;
  691. box-sizing: border-box;
  692. .head {
  693. width: 25%;
  694. position: fixed;
  695. top: 0;
  696. right: 0;
  697. background: #ffffff;
  698. padding: 20px;
  699. }
  700. .bottom {
  701. width: 25%;
  702. position: fixed;
  703. bottom: 0;
  704. right: 0;
  705. background: #ffffff;
  706. padding: 10px 0;
  707. }
  708. }
  709. .box-card {
  710. .item {
  711. cursor: pointer;
  712. margin-bottom: 6px;
  713. }
  714. .read1 {
  715. color: #f5680e;
  716. background: #fff2da;
  717. padding: 2px 4px;
  718. border-radius: 4px;
  719. font-size: 14px;
  720. }
  721. .read2 {
  722. color: #42b983;
  723. background: #d7fdde;
  724. padding: 2px 4px;
  725. border-radius: 4px;
  726. font-size: 14px;
  727. }
  728. }
  729. .navbar {
  730. width: 100%;
  731. height: 50px;
  732. overflow: hidden;
  733. background: #{$navbarBg};
  734. box-shadow: 0 1px 4px rgba(0, 21, 41, 0.08);
  735. display: flex;
  736. flex-direction: row;
  737. align-items: center;
  738. .hamburger-container {
  739. line-height: 46px;
  740. height: 100%;
  741. color: #{$navbarText};
  742. cursor: pointer;
  743. transition: background 0.3s;
  744. -webkit-tap-highlight-color: transparent;
  745. border-right: 1px solid #eaeaea;
  746. &:hover {
  747. background: rgba(0, 0, 0, 0.025);
  748. }
  749. }
  750. .menu_module {
  751. height: 100%;
  752. flex: 1;
  753. position: relative;
  754. .menu_module_view {
  755. position: absolute;
  756. top: 0;
  757. left: 0;
  758. bottom: 0;
  759. right: 0;
  760. .menu_module_fj {
  761. height: 100%;
  762. width: fit-content;
  763. white-space: nowrap;
  764. box-sizing: border-box;
  765. padding: 0 10px;
  766. .item {
  767. display: inline-block;
  768. height: 100%;
  769. line-height: 50px;
  770. box-sizing: border-box;
  771. padding: 0 10px;
  772. cursor: pointer;
  773. font-size: 14px;
  774. }
  775. .select {
  776. border-bottom: 1px solid #000;
  777. }
  778. }
  779. }
  780. }
  781. .flex {
  782. display: flex;
  783. align-items: center;
  784. }
  785. .ellipsis {
  786. display: inline-block;
  787. width: (16px * 6);
  788. white-space: nowrap;
  789. overflow: hidden;
  790. text-overflow: ellipsis;
  791. }
  792. .right-menu {
  793. height: 100%;
  794. line-height: 50px;
  795. & > div {
  796. float: left;
  797. }
  798. &:focus {
  799. outline: none;
  800. }
  801. .user-container {
  802. height: 50px;
  803. .user {
  804. i {
  805. font-size: 18px;
  806. margin-right: 5px;
  807. }
  808. span {
  809. font-size: 16px;
  810. }
  811. }
  812. }
  813. .right-menu-item {
  814. display: inline-block;
  815. padding: 0 15px;
  816. height: 100%;
  817. font-size: 18px;
  818. color: #{$navbarText};
  819. vertical-align: text-bottom;
  820. border-left: 1px solid #eaeaea;
  821. &.hover-effect {
  822. cursor: pointer;
  823. transition: background 0.3s;
  824. &:hover {
  825. background: rgba(0, 0, 0, 0.025);
  826. }
  827. }
  828. .notice-icon {
  829. padding-top: 0;
  830. padding-bottom: 0;
  831. }
  832. .right-menu-item {
  833. .notice-icon > i {
  834. font-size: 18px;
  835. }
  836. sup {
  837. top: 12px;
  838. right: 25px;
  839. }
  840. }
  841. }
  842. }
  843. }
  844. ::v-deep .el-badge__content.is-fixed {
  845. z-index: 99;
  846. }
  847. </style>