expert-knowledge-base.vue 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695
  1. <template>
  2. <div class="expert-knowledge-base">
  3. <el-row :gutter="16" class="up-box">
  4. <el-col :span="16">
  5. <!-- 故障体系 -->
  6. <el-row>
  7. <el-col :span="24">
  8. <div class="ekb-box">
  9. <el-row>
  10. <el-col :span="24" class="i-panel-title">
  11. <span class="svg-icon svg-icon-sm svg-icon-gray-l">
  12. <svg-icon svgid="svg-ekb-warn" />
  13. </span>
  14. <span class="gray-l font-md mg-l-16">故障体系</span>
  15. <span class="font-num font-md float-right green">3347</span>
  16. </el-col>
  17. </el-row>
  18. <el-row>
  19. <el-col :span="24">
  20. <el-scrollbar class="table">
  21. <table style="width:100%;" border="0" cellspacing="0">
  22. <tbody>
  23. <tr v-for="index of 6" :key="index">
  24. <td style="width:150px;" class="gray-l">
  25. MG01_01
  26. </td>
  27. <td class="green num" style="width:350px;">
  28. 1234.56
  29. </td>
  30. <td style="width:600px;">
  31. <div class="percent-item gray-l">
  32. 完成度
  33. <div class="percent-bar" style="">
  34. <div class="percent-value" style="width:80%"></div>
  35. </div>
  36. </div>
  37. </td>
  38. <td>
  39. <span class="perent-num">80%</span>
  40. </td>
  41. </tr>
  42. </tbody>
  43. </table>
  44. </el-scrollbar>
  45. </el-col>
  46. </el-row>
  47. </div>
  48. </el-col>
  49. </el-row>
  50. <!-- 预警知识 -->
  51. <el-row class="mg-t-16">
  52. <el-col :span="24">
  53. <div class="ekb-box">
  54. <el-row>
  55. <el-col :span="24" class="i-panel-title">
  56. <span class="svg-icon svg-icon-sm svg-icon-gray-l">
  57. <svg-icon svgid="svg-ekb-warning" />
  58. </span>
  59. <span class="gray-l font-md mg-l-16">预警知识</span>
  60. <span class="font-num font-md float-right green">3347</span>
  61. </el-col>
  62. </el-row>
  63. <el-row class="mg-t-16" :gutter="10">
  64. <el-col :span="6">
  65. <div class="warning-item">
  66. <div class="warning-icon-box">
  67. <div class="warning-icon">
  68. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  69. <svg-icon svgid="svg-ekb-generator" />
  70. </span>
  71. </div>
  72. </div>
  73. <div class="warning-info">
  74. <div class="warning-name gray-l">发电机</div>
  75. <div class="warning-count green font-num">9527</div>
  76. </div>
  77. </div>
  78. </el-col>
  79. <el-col :span="6">
  80. <div class="warning-item">
  81. <div class="warning-icon-box">
  82. <div class="warning-icon">
  83. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  84. <svg-icon svgid="svg-ekb-gear-box" />
  85. </span>
  86. </div>
  87. </div>
  88. <div class="warning-info">
  89. <div class="warning-name gray-l">齿轮箱</div>
  90. <div class="warning-count green font-num">9527</div>
  91. </div>
  92. </div>
  93. </el-col>
  94. <el-col :span="6">
  95. <div class="warning-item">
  96. <div class="warning-icon-box">
  97. <div class="warning-icon">
  98. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  99. <svg-icon svgid="svg-ekb-spindle" />
  100. </span>
  101. </div>
  102. </div>
  103. <div class="warning-info">
  104. <div class="warning-name gray-l">主轴</div>
  105. <div class="warning-count green font-num">9527</div>
  106. </div>
  107. </div>
  108. </el-col>
  109. <el-col :span="6">
  110. <div class="warning-item">
  111. <div class="warning-icon-box">
  112. <div class="warning-icon">
  113. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  114. <svg-icon svgid="svg-ekb-variable-pitch" />
  115. </span>
  116. </div>
  117. </div>
  118. <div class="warning-info">
  119. <div class="warning-name gray-l">变桨</div>
  120. <div class="warning-count green font-num">9527</div>
  121. </div>
  122. </div>
  123. </el-col>
  124. </el-row>
  125. <el-row class="mg-t-16" :gutter="10">
  126. <el-col :span="6">
  127. <div class="warning-item">
  128. <div class="warning-icon-box">
  129. <div class="warning-icon">
  130. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  131. <svg-icon svgid="svg-ekb-yaw" />
  132. </span>
  133. </div>
  134. </div>
  135. <div class="warning-info">
  136. <div class="warning-name gray-l">偏航</div>
  137. <div class="warning-count green font-num">9527</div>
  138. </div>
  139. </div>
  140. </el-col>
  141. <el-col :span="6">
  142. <div class="warning-item">
  143. <div class="warning-icon-box">
  144. <div class="warning-icon">
  145. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  146. <svg-icon svgid="svg-ekb-cabin" />
  147. </span>
  148. </div>
  149. </div>
  150. <div class="warning-info">
  151. <div class="warning-name gray-l">机舱</div>
  152. <div class="warning-count green font-num">9527</div>
  153. </div>
  154. </div>
  155. </el-col>
  156. <el-col :span="6">
  157. <div class="warning-item">
  158. <div class="warning-icon-box">
  159. <div class="warning-icon">
  160. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  161. <svg-icon svgid="svg-ekb-variable-frequency" />
  162. </span>
  163. </div>
  164. </div>
  165. <div class="warning-info">
  166. <div class="warning-name gray-l">变频</div>
  167. <div class="warning-count green font-num">9527</div>
  168. </div>
  169. </div>
  170. </el-col>
  171. <el-col :span="6">
  172. <div class="warning-item">
  173. <div class="warning-icon-box">
  174. <div class="warning-icon">
  175. <span class="svg-icon svg-icon-warning svg-icon-gray-l">
  176. <svg-icon svgid="svg-ekb-master" />
  177. </span>
  178. </div>
  179. </div>
  180. <div class="warning-info">
  181. <div class="warning-name gray-l">主控</div>
  182. <div class="warning-count green font-num">9527</div>
  183. </div>
  184. </div>
  185. </el-col>
  186. </el-row>
  187. </div>
  188. </el-col>
  189. </el-row>
  190. </el-col>
  191. <!-- 特征参数 -->
  192. <el-col :span="8">
  193. <div class="ekb-box">
  194. <el-row>
  195. <el-col :span="24" class="i-panel-title">
  196. <span class="svg-icon svg-icon-sm svg-icon-gray-l">
  197. <svg-icon svgid="svg-ekb-terminal" />
  198. </span>
  199. <span class="gray-l font-md mg-l-16">特征参数</span>
  200. <span class="font-num font-md float-right green">3347</span>
  201. </el-col>
  202. </el-row>
  203. <el-row class="mg-t-16" :gutter="16">
  204. <el-col :span="12">
  205. <div class="characteristic-parameters-item">
  206. <div class="characteristic-parameters-icon">
  207. <span class="svg-icon svg-icon-size-icon svg-icon-color-icon">
  208. <svg-icon svgid="svg-ekb-rank" />
  209. </span>
  210. </div>
  211. <div class="characteristic-parameters-name">基于数据统计</div>
  212. <div class="characteristic-parameters-count font-num green">9</div>
  213. <div class="characteristic-parameters-back">
  214. <span class="svg-icon svg-icon-size-back svg-icon-color-back">
  215. <svg-icon svgid="svg-ekb-rank" />
  216. </span>
  217. </div>
  218. </div>
  219. </el-col>
  220. <el-col :span="12">
  221. <div class="characteristic-parameters-item">
  222. <div class="characteristic-parameters-icon">
  223. <span class="svg-icon svg-icon-size-icon svg-icon-color-icon">
  224. <svg-icon svgid="svg-ekb-neural-network" />
  225. </span>
  226. </div>
  227. <div class="characteristic-parameters-name">神经网络整理</div>
  228. <div class="characteristic-parameters-count font-num green">95</div>
  229. <div class="characteristic-parameters-back">
  230. <span class="svg-icon svg-icon-size-back svg-icon-color-back">
  231. <svg-icon svgid="svg-ekb-neural-network" />
  232. </span>
  233. </div>
  234. </div>
  235. </el-col>
  236. </el-row>
  237. <el-row class="mg-t-16" :gutter="16">
  238. <el-col :span="12">
  239. <div class="characteristic-parameters-item">
  240. <div class="characteristic-parameters-icon">
  241. <span class="svg-icon svg-icon-size-icon svg-icon-color-icon">
  242. <svg-icon svgid="svg-ekb-document" />
  243. </span>
  244. </div>
  245. <div class="characteristic-parameters-name">文档整理</div>
  246. <div class="characteristic-parameters-count font-num green">952</div>
  247. <div class="characteristic-parameters-back">
  248. <span class="svg-icon svg-icon-size-back svg-icon-color-back">
  249. <svg-icon svgid="svg-ekb-document" />
  250. </span>
  251. </div>
  252. </div>
  253. </el-col>
  254. <el-col :span="12">
  255. <div class="characteristic-parameters-item">
  256. <div class="characteristic-parameters-icon">
  257. <span class="svg-icon svg-icon-size-icon svg-icon-color-icon">
  258. <svg-icon svgid="svg-ekb-experts" />
  259. </span>
  260. </div>
  261. <div class="characteristic-parameters-name">专家知识分析</div>
  262. <div class="characteristic-parameters-count font-num green">9527</div>
  263. <div class="characteristic-parameters-back">
  264. <span class="svg-icon svg-icon-size-back svg-icon-color-back">
  265. <svg-icon svgid="svg-ekb-experts" />
  266. </span>
  267. </div>
  268. </div>
  269. </el-col>
  270. </el-row>
  271. </div>
  272. </el-col>
  273. </el-row>
  274. <el-row class="mg-t-16 down-box" :gutter="8">
  275. <el-col :span="8">
  276. <div class="ekb-box q-box-p">
  277. <el-row>
  278. <el-col :span="24" class="i-panel-title">
  279. <span class="svg-icon svg-icon-sm svg-icon-gray-l">
  280. <svg-icon svgid="svg-ekb-terminal" />
  281. </span>
  282. <span class="gray-l font-md mg-l-16">排查、检修方案</span>
  283. <span class="font-num font-md float-right green">3347</span>
  284. </el-col>
  285. </el-row>
  286. <el-row class="q-box">
  287. <el-col :span="24">
  288. <div class="circle-items">
  289. <div class="circle-item">
  290. <div class="inner">
  291. <div class="text">健康评价</div>
  292. <div class="value">29</div>
  293. </div>
  294. </div>
  295. <div class="circle-item">
  296. <div class="inner">
  297. <div class="text">健康评价</div>
  298. <div class="value">29</div>
  299. </div>
  300. </div>
  301. <div class="circle-item">
  302. <div class="inner">
  303. <div class="text">健康评价</div>
  304. <div class="value">29</div>
  305. </div>
  306. </div>
  307. </div>
  308. </el-col>
  309. </el-row>
  310. </div>
  311. </el-col>
  312. <el-col :span="8">
  313. <div class="ekb-box q-box-p">
  314. <el-row>
  315. <el-col :span="24" class="i-panel-title">
  316. <span class="svg-icon svg-icon-sm svg-icon-gray-l">
  317. <svg-icon svgid="svg-ekb-terminal" />
  318. </span>
  319. <span class="gray-l font-md mg-l-16">排查、检修方案</span>
  320. <span class="font-num font-md float-right green">3347</span>
  321. </el-col>
  322. </el-row>
  323. <el-row class="q-box">
  324. <el-col :span="24">
  325. <div class="circle-items">
  326. <div class="circle-item">
  327. <div class="inner">
  328. <div class="text">健康评价</div>
  329. <div class="value">29</div>
  330. </div>
  331. </div>
  332. <div class="circle-item">
  333. <div class="inner">
  334. <div class="text">健康评价</div>
  335. <div class="value">29</div>
  336. </div>
  337. </div>
  338. <div class="circle-item">
  339. <div class="inner">
  340. <div class="text">健康评价</div>
  341. <div class="value">29</div>
  342. </div>
  343. </div>
  344. </div>
  345. </el-col>
  346. </el-row>
  347. </div>
  348. </el-col>
  349. <el-col :span="8">
  350. <div class="ekb-box q-box-p">
  351. <el-row>
  352. <el-col :span="24" class="i-panel-title">
  353. <span class="svg-icon svg-icon-sm svg-icon-gray-l">
  354. <svg-icon svgid="svg-ekb-terminal" />
  355. </span>
  356. <span class="gray-l font-md mg-l-16">排查、检修方案</span>
  357. <span class="font-num font-md float-right green">3347</span>
  358. </el-col>
  359. </el-row>
  360. <el-row class="q-box">
  361. <el-col :span="24">
  362. <div class="circle-items">
  363. <div class="circle-item">
  364. <div class="inner">
  365. <div class="text">健康评价</div>
  366. <div class="value">29</div>
  367. </div>
  368. </div>
  369. <div class="circle-item">
  370. <div class="inner">
  371. <div class="text">健康评价</div>
  372. <div class="value">29</div>
  373. </div>
  374. </div>
  375. <div class="circle-item">
  376. <div class="inner">
  377. <div class="text">健康评价</div>
  378. <div class="value">29</div>
  379. </div>
  380. </div>
  381. </div>
  382. </el-col>
  383. </el-row>
  384. </div>
  385. </el-col>
  386. </el-row>
  387. </div>
  388. </template>
  389. <script>
  390. import SvgIcon from "@com/coms/icon/svg-icon.vue";
  391. export default {
  392. setup() {},
  393. components: { SvgIcon },
  394. data() {
  395. return {};
  396. },
  397. created() {},
  398. };
  399. </script>
  400. <style lang="less">
  401. .expert-knowledge-base {
  402. .svg-icon-sm {
  403. width: 20px;
  404. height: 16px;
  405. line-height: 1;
  406. svg {
  407. width: 20px;
  408. height: 16px;
  409. }
  410. }
  411. .svg-icon-size-icon {
  412. width: 26px;
  413. height: 26px;
  414. line-height: 1;
  415. svg {
  416. width: 26px;
  417. height: 26px;
  418. }
  419. }
  420. .svg-icon-color-icon {
  421. svg {
  422. use {
  423. fill: #b9bfc17f;
  424. }
  425. }
  426. }
  427. .svg-icon-size-back {
  428. width: 110px;
  429. height: 110px;
  430. line-height: 1;
  431. svg {
  432. width: 110px;
  433. height: 110px;
  434. }
  435. }
  436. .svg-icon-color-back {
  437. svg {
  438. use {
  439. fill: #60676933;
  440. }
  441. }
  442. }
  443. .svg-icon-warning {
  444. width: 24px;
  445. height: 24px;
  446. line-height: 1;
  447. svg {
  448. width: 24px;
  449. height: 24px;
  450. }
  451. }
  452. .font-md {
  453. font-size: 14px;
  454. line-height: 16px;
  455. font-weight: 400;
  456. }
  457. .float-right {
  458. float: right;
  459. margin-left: auto;
  460. }
  461. .el-col {
  462. padding: 0;
  463. }
  464. .up-box {
  465. height: 650px;
  466. overflow: hidden;
  467. }
  468. .down-box {
  469. height: calc(100vh - 735px);
  470. overflow: hidden;
  471. }
  472. .i-panel-title {
  473. height: 33px;
  474. background: #53626833;
  475. padding: 8px 26px;
  476. display: flex;
  477. align-items: center;
  478. }
  479. .ekb-box {
  480. border: 1px solid #53626866;
  481. }
  482. .warning-item {
  483. background: #53626833;
  484. padding: 11px 0;
  485. display: flex;
  486. .warning-icon-box {
  487. width: 116px;
  488. height: 148px;
  489. border-right: 2px dotted #b9bfc133;
  490. display: flex;
  491. align-items: center;
  492. justify-content: center;
  493. .warning-icon {
  494. width: 56px;
  495. height: 56px;
  496. border-radius: 50%;
  497. border: 1px solid #b9bfc17f;
  498. display: flex;
  499. align-items: center;
  500. justify-content: center;
  501. }
  502. }
  503. .warning-info {
  504. padding: 43px 0 0 30px;
  505. .warning-name {
  506. font-size: 20px;
  507. font-weight: 400;
  508. line-height: 1;
  509. }
  510. .warning-count {
  511. font-size: 30px;
  512. font-weight: 400;
  513. line-height: 1;
  514. margin-top: 22px;
  515. }
  516. }
  517. }
  518. .characteristic-parameters-item {
  519. background: #53626833;
  520. padding: 36px 0 0 36px;
  521. position: relative;
  522. height: 294px;
  523. .characteristic-parameters-icon {
  524. width: 70px;
  525. height: 70px;
  526. border-radius: 50%;
  527. border: 1px solid #b9bfc17f;
  528. display: flex;
  529. align-items: center;
  530. justify-content: center;
  531. }
  532. .characteristic-parameters-name {
  533. margin-top: 30px;
  534. font-size: 20px;
  535. font-weight: 400;
  536. color: #b9bfc1;
  537. line-height: 1;
  538. }
  539. .characteristic-parameters-count {
  540. margin-top: 20px;
  541. font-weight: 400;
  542. line-height: 1;
  543. font-size: 30px;
  544. }
  545. .characteristic-parameters-back {
  546. width: 110px;
  547. height: 110px;
  548. position: absolute;
  549. right: 0;
  550. bottom: 0;
  551. }
  552. }
  553. .table {
  554. height: 198px;
  555. tbody {
  556. tr:nth-child(2n) td {
  557. background-color: fade(@gray, 20%);
  558. &.item {
  559. background-color: transparent;
  560. }
  561. }
  562. }
  563. td {
  564. color: @gray;
  565. text-align: center;
  566. height: 26px;
  567. line-height: 26px;
  568. font-size: 12px;
  569. &.gray-l {
  570. color: @gray-l;
  571. }
  572. &.green {
  573. color: @green;
  574. }
  575. &.num {
  576. font-family: @font-family-num;
  577. }
  578. }
  579. .percent-item {
  580. display: flex;
  581. align-items: center;
  582. justify-content: center;
  583. height: 31px;
  584. .percent-bar {
  585. height: 12px;
  586. width: 430px;
  587. background: transparent;
  588. border: 1px solid @gray;
  589. margin-left: 16px;
  590. .percent-value {
  591. height: calc(100% - 4px);
  592. background: @green;
  593. margin: 2px;
  594. }
  595. }
  596. }
  597. .perent-num {
  598. color: @green;
  599. margin-left: 16px;
  600. font-family: @font-family-num;
  601. }
  602. }
  603. .q-box-p {
  604. height: 100%;
  605. .q-box {
  606. height: calc(100% - 33px);
  607. }
  608. }
  609. .circle-items {
  610. display: flex;
  611. justify-content: space-around;
  612. align-items: center;
  613. height: 100%;
  614. .circle-item {
  615. display: flex;
  616. flex: 0 0 146px;
  617. width: 146px;
  618. height: 146px;
  619. background: fade(@green, 10);
  620. border-radius: 50%;
  621. justify-content: center;
  622. align-items: center;
  623. .inner {
  624. width: 124px;
  625. height: 124px;
  626. border: 1px solid #05bb4c;
  627. border-radius: 50%;
  628. display: flex;
  629. flex-direction: column;
  630. justify-content: center;
  631. align-items: center;
  632. box-shadow: inset -15px 20px 30px -30px #05bb4c;
  633. .text {
  634. color: @green;
  635. font-size: 12px;
  636. margin-bottom: 8px;
  637. }
  638. .value {
  639. color: @white;
  640. font-size: 34px;
  641. }
  642. }
  643. }
  644. }
  645. }
  646. </style>