ReportDisposal.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728
  1. <template>
  2. <div class="body_container">
  3. <!-- 1.============= -->
  4. <div class="content_one">
  5. <!-- 风险报告 -->
  6. <div class="modules_bg_color modules_bg">
  7. <TitleHeadermini :title="'风险报告'"></TitleHeadermini>
  8. <div>
  9. <RiskReport :levelObj="riskReportObj"></RiskReport>
  10. </div>
  11. </div>
  12. <!-- 风险总览 -->
  13. <div class="modules_bg_color modules_bg2">
  14. <TitleHeader :title="'风险总览'" :buttons="riskOverViewButtons"></TitleHeader>
  15. <div class="modules_bg2_body">
  16. <div>
  17. <RiskReport :levelObj="riskOverViewObj"></RiskReport>
  18. </div>
  19. <div class="modules_bg2_body_right">
  20. <TowLevelTitle :title="riskOverViewtTitle" :buttons="riskOverViewTwoButtons"></TowLevelTitle>
  21. <div class="modules_bg2_body_bar">
  22. <RingChart></RingChart>
  23. </div>
  24. </div>
  25. </div>
  26. </div>
  27. </div>
  28. <!-- 2.=================== -->
  29. <div class="content_two">
  30. <!-- 风险处置 -->
  31. <div class="modules_bg_color modules_bg_340">
  32. <TitleHeadersmall :title="'风险处置'" :buttons="timeButtons"></TitleHeadersmall>
  33. <div class="two_level_body">
  34. <RiskTwoView :levelObj="riskTwoViewObj"></RiskTwoView>
  35. </div>
  36. </div>
  37. <!-- 重大活动保障 -->
  38. <div class="modules_bg_color modules_bg_340">
  39. <TitleHeadersmall :title="'重大活动保障'" :buttons="timeButtons"></TitleHeadersmall>
  40. <div class="two_level_body">
  41. <RiskTwoView :levelObj="majorEventGuaranteeObj"></RiskTwoView>
  42. </div>
  43. </div>
  44. <!-- 已结案风险 -->
  45. <div class="modules_bg_color modules_bg_412">
  46. <TitleHeadersmall :title="'已结案风险'" :buttons="timeButtons"></TitleHeadersmall>
  47. <div class="two_level_body">
  48. <RiskTwoView :levelObj="riskClosedCaseObj"></RiskTwoView>
  49. </div>
  50. </div>
  51. </div>
  52. <!-- 3.========================= -->
  53. <div class="content_three">
  54. <div class="open_icon" @click="openRiskBigTable"><img src="../../../assets/img/展开箭头.png" alt="" /></div>
  55. <TitleHeaderLong :title="'风险列表'" :buttons="riskTableButtons"></TitleHeaderLong>
  56. <dv-scroll-board :config="riskTableconfig" class="scroll_table" ref="scrollBoard" />
  57. </div>
  58. <!-- 4.===================== -->
  59. <div class="content_four">
  60. <TitleHeaderLong :title="'应急处置资源'" :buttons="[]"></TitleHeaderLong>
  61. <div class="modules_bg_color content_four_body">
  62. <!-- 检测设备 -->
  63. <div class="modules_bg_color modules_bg_jcsb">
  64. <TowLevelTitle :title="'检测设备'"></TowLevelTitle>
  65. <div class="modules_bg_jcsb_body">
  66. <!-- <RiskTwoView :levelObj="riskTwoViewObj"></RiskTwoView> -->
  67. <div class="modules_bg_jcsb_body_left">
  68. <div class="modules_bg_jcsb_body_left_content">
  69. <div>
  70. <img src="../../../assets//img/装备总数.png" alt="" />
  71. <div>装备总数</div>
  72. <span>205</span>
  73. </div>
  74. <img src="../../../assets/img/方向箭头.png" alt="" />
  75. <div>
  76. <div>使用中</div>
  77. <span>108</span>
  78. </div>
  79. </div>
  80. </div>
  81. <div class="progress">
  82. <!-- <el-progress class="circle" type="circle" :percentage="52" /> -->
  83. <!-- <MyProgress :percentage="52" :gradientStart="'#83804f'" :gradientEnd="'#ffca0c'"></MyProgress> -->
  84. <MyProgress :value="50" backgroundColor="#2d4c7f" gradient-start="#83804f" gradient-end="#ffca0c" text-color="#ffffff" stroke-width="8" size="60" ></MyProgress>
  85. <span class="text">使用率</span>
  86. </div>
  87. </div>
  88. </div>
  89. <!-- 派单情况 -->
  90. <div class="modules_bg_color modules_bg_pdqk">
  91. <TowLevelTitle :title="'派单情况'"></TowLevelTitle>
  92. <div class="modules_bg_pdqk_body">
  93. <div class="modules_bg_pdqk_body_item">
  94. <img src="../../../assets//img/发出指令.png" alt="" />
  95. <div>发出指令</div>
  96. <span>25</span>
  97. </div>
  98. <!-- <img src="../../../assets/img/连线方向箭头.png" alt="" class="line_img"> -->
  99. <div class="modules_bg_pdqk_body_item">
  100. <img src="../../../assets//img/签收指令.png" alt="" />
  101. <div>签收指令</div>
  102. <span>22</span>
  103. </div>
  104. <!-- <img src="../../../assets/img/连线方向箭头.png" alt="" class="line_img"> -->
  105. <div class="modules_bg_pdqk_body_item">
  106. <img src="../../../assets//img/完成指令.png" alt="" />
  107. <div>完成指令</div>
  108. <span>17</span>
  109. </div>
  110. <div class="line">
  111. <img src="../../../assets/img/连线方向箭头.png" alt="" class="line_img1" />
  112. <img src="../../../assets/img/连线方向箭头.png" alt="" class="line_img2" />
  113. </div>
  114. </div>
  115. </div>
  116. <!-- 应急人员 -->
  117. <div class="modules_bg_color modules_bg_yjry">
  118. <TowLevelTitle :title="'应急人员'"></TowLevelTitle>
  119. <div class="modules_bg_yjry_body">
  120. <!-- <RiskTwoView :levelObj="riskTwoViewObj"></RiskTwoView> -->
  121. <div class="modules_bg_yjry_body_zhz">
  122. <img src="../../../assets//img/指挥长.png" alt="" />
  123. <span>指挥长</span>
  124. <div>
  125. 张三
  126. <img src="../../../assets/img/视频电话.png" alt="" />
  127. </div>
  128. </div>
  129. <div class="line"></div>
  130. <div class="modules_bg_yjry_left_content">
  131. <div class="modules_bg_yjry_left">
  132. <div class="modules_bg_yjry_left_content">
  133. <div>
  134. <img src="../../../assets//img/装备总数.png" alt="" />
  135. <div>备班人数</div>
  136. <span>205</span>
  137. </div>
  138. <img src="../../../assets/img/方向箭头.png" alt="" />
  139. <div>
  140. <div>出动数</div>
  141. <span>108</span>
  142. </div>
  143. </div>
  144. </div>
  145. <div class="progress">
  146. <!-- <el-progress class="circle" type="circle" :percentage="52" /> -->
  147. <!-- <MyProgress :percentage="50" :gradientStart="'#9ee6f6'" :gradientEnd="'#62e3ff'"></MyProgress> -->
  148. <MyProgress :value="50" backgroundColor="#2d4c7f" gradient-start="#9ee6f6" gradient-end="#62e3ff" text-color="#ffffff" stroke-width="8" size="60" ></MyProgress>
  149. <span class="text">出动率</span>
  150. </div>
  151. </div>
  152. </div>
  153. </div>
  154. <!-- 应急车辆 -->
  155. <div class="modules_bg_color modules_bg_jcsb">
  156. <TowLevelTitle :title="'应急车辆'"></TowLevelTitle>
  157. <div class="modules_bg_jcsb_body">
  158. <!-- <RiskTwoView :levelObj="riskTwoViewObj"></RiskTwoView> -->
  159. <div class="modules_bg_jcsb_body_left">
  160. <div class="modules_bg_jcsb_body_left_content">
  161. <div>
  162. <img src="../../../assets//img/车辆.png" alt="" />
  163. <div>车辆</div>
  164. <span>115</span>
  165. </div>
  166. <img src="../../../assets/img/方向箭头.png" alt="" />
  167. <div>
  168. <div>出动数</div>
  169. <span>90</span>
  170. </div>
  171. </div>
  172. </div>
  173. <div class="progress">
  174. <!-- <el-progress class="circle" type="circle" :percentage="78" /> -->
  175. <!-- <MyProgress :percentage="78" :gradientStart="'#ecc5af'" :gradientEnd="'#ff9a62'"></MyProgress> -->
  176. <MyProgress :value="78" backgroundColor="#2d4c7f" gradient-start="#ecc5af" gradient-end="#ff9a62" text-color="#ffffff" stroke-width="8" size="60" ></MyProgress>
  177. <span class="text">出动率</span>
  178. </div>
  179. </div>
  180. </div>
  181. </div>
  182. </div>
  183. </div>
  184. </template>
  185. <script setup>
  186. import RingChart from '../comp/RingChart.vue'
  187. import TitleHeadermini from '../../../components/TitleHeadermini'
  188. import TitleHeadersmall from '../../../components/TitleHeadersmall'
  189. import TitleHeader from '../../../components/TitleHeader'
  190. import TitleHeaderLong from '../../../components/TitleHeaderLong'
  191. import TowLevelTitle from '../../../components/TowLevelTitle'
  192. import RiskReport from '../comp/RiskReport.vue'
  193. import RiskTwoView from '../comp/RiskTwoView.vue'
  194. import MyProgress from './common/MyProgress'
  195. import { ref, nextTick, toRaw, reactive, toRefs, onBeforeMount, onMounted } from 'vue'
  196. // let riskReportObj = ref([{ id: 1, level: 'A', count: 0 }, { id: 2, level: 'B', count: 0 }, { id: 3, level: 'C', count: 0 }, { id: 4, level: 'D', count: 0 },])
  197. const emit = defineEmits(['openRiskBigTable'])
  198. // 1.=====================================
  199. let riskReportObj = ref({
  200. name: '当日新增',
  201. count: 5,
  202. levelList: [
  203. { id: 1, level: 'A', count: 1 },
  204. { id: 2, level: 'B', count: 0 },
  205. { id: 3, level: 'C', count: 2 },
  206. { id: 4, level: 'D', count: 3 }
  207. ]
  208. })
  209. let riskOverViewObj = ref({
  210. name: '当年累计',
  211. count: 102,
  212. levelList: [
  213. { id: 1, level: 'A', count: 12 },
  214. { id: 2, level: 'B', count: 51 },
  215. { id: 3, level: 'C', count: 33 },
  216. { id: 4, level: 'D', count: 42 }
  217. ]
  218. })
  219. const riskOverViewButtons = ref([
  220. { id: 1, name: '月', active: false },
  221. { id: 2, name: '年', active: true }
  222. ])
  223. const riskOverViewTwoButtons = ref([
  224. { id: 1, name: '按分类', active: false },
  225. { id: 2, name: '按级别', active: true }
  226. ])
  227. const riskOverViewtTitle = ref('公共卫生风险分布图')
  228. // 2.====================================================
  229. const timeButtons = ref([
  230. { id: 1, name: '日', active: false },
  231. { id: 1, name: '月', active: false },
  232. { id: 2, name: '年', active: true }
  233. ])
  234. // 风险处置
  235. const riskTwoViewObj = ref({
  236. name: '处置中',
  237. count: 102,
  238. levelList: [
  239. { id: 1, level: 'A', count: 12 },
  240. { id: 2, level: 'B', count: 51 },
  241. { id: 3, level: 'C', count: 33 },
  242. { id: 4, level: 'D', count: 42 }
  243. ]
  244. })
  245. // 重大活动保障
  246. const majorEventGuaranteeObj = ref({
  247. name: '处置中',
  248. count: 102,
  249. levelList: [
  250. { id: 1, level: 'A', count: 12 },
  251. { id: 2, level: 'B', count: 51 },
  252. { id: 3, level: 'C', count: 33 },
  253. { id: 4, level: 'D', count: 42 }
  254. ]
  255. })
  256. // 已结案风险
  257. const riskClosedCaseObj = ref({
  258. name: '已结案',
  259. count: 5,
  260. levelList: [
  261. { id: 1, level: 'A', count: 1 },
  262. { id: 2, level: 'B', count: 0 },
  263. { id: 3, level: 'C', count: 2 },
  264. { id: 4, level: 'D', count: 3 },
  265. { id: 4, level: '突发', count: 3 }
  266. ]
  267. })
  268. // 3.风险列表=======================
  269. const riskTableButtons = ref([
  270. { id: 1, name: '处置中', active: false },
  271. { id: 2, name: '已结案', active: true },
  272. { id: 3, name: '重大活动', active: true }
  273. ])
  274. const riskTableconfig = ref({
  275. indexHeader: '编号',
  276. header: ['事件名称', '风险等级', '报告单位', '报告时间', '发生地点', '处置单位', '病例数', '重点场所', '重点人群', '最新状态'],
  277. data: [
  278. ['行1列', '行1列2', '行1列3', '行1列1', '行1列2', '行1列3', '行1列1', '行1列2', '行1列3', '行1列1'],
  279. ['行2列1', '行2列2', '行2列3'],
  280. ['行3列1', '行3列2', '行3列3'],
  281. ['行4列1', '行4列2', '行4列3'],
  282. ['行5列1', '行5列2', '行5列3'],
  283. ['行6列1', '行6列2', '行6列3'],
  284. ['行7列1', '行7列2', '行7列3'],
  285. ['行8列1', '行8列2', '行8列3'],
  286. ['行9列1', '行9列2', '行9列3'],
  287. ['行10列1', '行10列2', '行10列3']
  288. ],
  289. rowNum: 3,
  290. index: true,
  291. columnWidth: [50],
  292. align: ['center'],
  293. headerBGC: 'rgba(34, 155, 188, 0.3)',
  294. headerHeight: 38,
  295. oddRowBGC: 'rgba(0, 170, 255, 0.15)',
  296. evenRowBGC: 'rgba(10, 39, 50, 0.15)',
  297. hoverPause: true,
  298. rowClass: 'custom-row-style'
  299. // itemStyle: {
  300. // height: '40px',
  301. // lineHeight: '40px',
  302. // marginBottom: '10px'
  303. // }
  304. })
  305. function openRiskBigTable() {
  306. console.log('openRiskBigTable')
  307. emit('openRiskBigTable')
  308. }
  309. </script>
  310. <style lang="scss" scoped>
  311. .body_container {
  312. width: 100%;
  313. height: 100%;
  314. box-sizing: border-box;
  315. display: flex;
  316. flex-direction: column;
  317. gap: 18px;
  318. }
  319. .content_one {
  320. display: flex;
  321. gap: 20px;
  322. }
  323. .modules_bg_color {
  324. background: linear-gradient(180deg, rgba(32, 70, 121, 0) 2%, rgba(32, 70, 121, 0.6) 100%);
  325. border-radius: 0px 0px 0px 0px;
  326. // border: 1px solid;
  327. border-image: linear-gradient(180deg, rgba(7, 108, 208, 0), rgba(168, 212, 235, 1)) 1 1;
  328. }
  329. .modules_bg {
  330. display: flex;
  331. flex-direction: column;
  332. justify-content: center;
  333. align-items: center;
  334. width: 300px;
  335. height: 253px;
  336. // background: url('../../../assets/img/m_bg.png');
  337. }
  338. .modules_bg2 {
  339. width: 808px;
  340. height: 253px;
  341. padding-left: 10px;
  342. display: flex;
  343. flex-direction: column;
  344. justify-content: center;
  345. }
  346. .modules_bg2_body {
  347. display: flex;
  348. justify-content: space-between;
  349. }
  350. .modules_bg2_body_right {
  351. flex: 1;
  352. display: flex;
  353. flex-direction: column;
  354. width: 494px;
  355. margin-left: 10px;
  356. }
  357. .modules_bg2_body_bar {
  358. // flex: 1;
  359. width: 444px;
  360. height: 144px;
  361. color: azure;
  362. // background-color: pink;
  363. margin: 0 auto;
  364. }
  365. .content_two {
  366. display: flex;
  367. gap: 20px;
  368. }
  369. .modules_bg_340 {
  370. width: 340px;
  371. height: 187px;
  372. padding: 0 10px;
  373. }
  374. .modules_bg_412 {
  375. width: 412px;
  376. height: 187px;
  377. padding: 0 10px;
  378. }
  379. .two_level_body {
  380. width: 100%;
  381. }
  382. .content_three {
  383. width: 1124px;
  384. height: 222px;
  385. position: relative;
  386. .open_icon {
  387. width: 24px;
  388. height: 24px;
  389. position: absolute;
  390. top: 6px;
  391. left: 180px;
  392. z-index: 999;
  393. }
  394. .scroll_table {
  395. height: 166px;
  396. width: 100%;
  397. }
  398. }
  399. .content_four {
  400. // flex: 1;
  401. width: 100%;
  402. height: 202px;
  403. .content_four_body {
  404. height: 146px;
  405. padding: 0 10px;
  406. display: flex;
  407. align-items: center;
  408. justify-content: space-between;
  409. background: linear-gradient(180deg, rgba(32, 70, 121, 0) 2%, rgba(32, 70, 121, 0.6) 100%);
  410. border-radius: 0px 0px 0px 0px;
  411. border: 1px solid;
  412. border-image: linear-gradient(180deg, rgba(7, 108, 208, 0), rgba(168, 212, 235, 1)) 1 1;
  413. }
  414. // 检测设备 应急车辆
  415. .modules_bg_jcsb {
  416. width: 223px;
  417. height: 126px;
  418. padding: 5px 5px 0px;
  419. // padding-left: 5px;
  420. box-sizing: border-box;
  421. .modules_bg_jcsb_body {
  422. display: flex;
  423. justify-content: space-between;
  424. .modules_bg_jcsb_body_left {
  425. width: 140px;
  426. .modules_bg_jcsb_body_left_content {
  427. display: flex;
  428. align-items: end;
  429. justify-content: space-between;
  430. width: 140;
  431. > div {
  432. display: flex;
  433. flex-direction: column;
  434. align-items: center;
  435. font-family: Alibaba PuHuiTi 3, Alibaba PuHuiTi 30;
  436. font-weight: normal;
  437. font-size: 14px;
  438. color: rgba(255, 255, 255, 0.9);
  439. font-style: normal;
  440. text-transform: none;
  441. > span {
  442. font-family: Roboto, Roboto;
  443. font-weight: bold;
  444. font-size: 16px;
  445. font-style: normal;
  446. text-transform: none;
  447. background: linear-gradient(to bottom, #ffffff 4%, #49ffff 100%);
  448. -webkit-background-clip: text;
  449. -webkit-text-fill-color: transparent;
  450. }
  451. }
  452. > img {
  453. width: 22px;
  454. height: 21px;
  455. margin: 0px 5px 10px 5px;
  456. }
  457. }
  458. }
  459. .progress {
  460. margin-top: 5px;
  461. width: 54px;
  462. height: 76px;
  463. display: flex;
  464. flex-direction: column;
  465. align-items: center;
  466. // justify-content: center;
  467. .text {
  468. font-family: Alibaba PuHuiTi 3, Alibaba PuHuiTi 30;
  469. font-weight: normal;
  470. font-size: 14px;
  471. color: rgba(255, 255, 255, 0.9);
  472. font-style: normal;
  473. text-transform: none;
  474. margin-top: 6px;
  475. }
  476. .circle {
  477. display: flex;
  478. justify-content: center;
  479. align-items: center;
  480. margin-top: 12px;
  481. width: 48px;
  482. height: 48px;
  483. :deep(.el-progress-circle) {
  484. width: 48px !important;
  485. height: 48px !important;
  486. }
  487. }
  488. }
  489. }
  490. }
  491. // 派单情况
  492. .modules_bg_pdqk {
  493. width: 300px;
  494. height: 126px;
  495. padding: 5px 20px 10px;
  496. box-sizing: border-box;
  497. .modules_bg_pdqk_body {
  498. display: flex;
  499. align-items: start;
  500. justify-content: space-between;
  501. position: relative;
  502. .modules_bg_pdqk_body_item {
  503. display: flex;
  504. flex-direction: column;
  505. align-items: center;
  506. font-family: Alibaba PuHuiTi 30;
  507. font-weight: normal;
  508. font-size: 14px;
  509. color: rgba(255, 255, 255, 0.9);
  510. font-style: normal;
  511. text-transform: none;
  512. > span {
  513. font-family: Roboto, Roboto;
  514. font-weight: bold;
  515. font-size: 16px;
  516. font-style: normal;
  517. text-transform: none;
  518. background: linear-gradient(to bottom, #ffffff 4%, #49ffff 100%);
  519. -webkit-background-clip: text;
  520. -webkit-text-fill-color: transparent;
  521. }
  522. .line_img {
  523. width: 16px;
  524. height: 16px;
  525. }
  526. }
  527. .line {
  528. position: absolute;
  529. top: 10px;
  530. left: 24px;
  531. width: 192px;
  532. height: 16px;
  533. border-bottom: 2px dashed #175a7e;
  534. // position: relative;
  535. .line_img1 {
  536. // position: absolute;
  537. // top:0px;
  538. // left: 0px;
  539. width: 26px;
  540. height: 26px;
  541. margin-left: 50px;
  542. margin-top: 4px;
  543. margin-right: 70px;
  544. }
  545. .line_img2 {
  546. margin-top: 4px;
  547. width: 26px;
  548. height: 26px;
  549. }
  550. }
  551. }
  552. }
  553. // 应急人员
  554. .modules_bg_yjry {
  555. width: 322px;
  556. height: 126px;
  557. padding: 5px 5px 5px;
  558. // padding-left: 10px;
  559. box-sizing: border-box;
  560. .modules_bg_yjry_body {
  561. display: flex;
  562. align-items: center;
  563. height: 82px;
  564. .modules_bg_yjry_body_zhz {
  565. display: flex;
  566. flex-direction: column;
  567. align-items: center;
  568. font-family: Alibaba PuHuiTi 3, Alibaba PuHuiTi 30;
  569. font-weight: normal;
  570. font-size: 14px;
  571. color: rgba(255, 255, 255, 0.9);
  572. font-style: normal;
  573. text-transform: none;
  574. > div {
  575. display: flex;
  576. align-items: center;
  577. font-family: Alibaba PuHuiTi 3, Alibaba PuHuiTi 30;
  578. font-weight: normal;
  579. font-size: 14px;
  580. color: #08ffe5;
  581. font-style: normal;
  582. text-transform: none;
  583. > img {
  584. width: 24px;
  585. height: 24px;
  586. margin-left: 5px;
  587. }
  588. }
  589. }
  590. .modules_bg_yjry_left_content {
  591. display: flex;
  592. align-items: center;
  593. width: 150px;
  594. .modules_bg_yjry_left {
  595. width: 150px;
  596. margin-right: 15px;
  597. .modules_bg_yjry_left_content {
  598. display: flex;
  599. align-items: end;
  600. justify-content: space-between;
  601. width: 150;
  602. > div {
  603. display: flex;
  604. flex-direction: column;
  605. align-items: center;
  606. font-family: Alibaba PuHuiTi 3, Alibaba PuHuiTi 30;
  607. font-weight: normal;
  608. font-size: 14px;
  609. color: rgba(255, 255, 255, 0.9);
  610. font-style: normal;
  611. text-transform: none;
  612. > span {
  613. font-family: Roboto, Roboto;
  614. font-weight: bold;
  615. font-size: 16px;
  616. font-style: normal;
  617. text-transform: none;
  618. background: linear-gradient(to bottom, #ffffff 4%, #49ffff 100%);
  619. -webkit-background-clip: text;
  620. -webkit-text-fill-color: transparent;
  621. }
  622. }
  623. > img {
  624. width: 22px;
  625. height: 21px;
  626. margin: 0px 5px 10px 5px;
  627. }
  628. }
  629. }
  630. .progress {
  631. width: 54px;
  632. height: 76px;
  633. display: flex;
  634. flex-direction: column;
  635. align-items: center;
  636. // justify-content: center;
  637. .text {
  638. font-family: Alibaba PuHuiTi 3, Alibaba PuHuiTi 30;
  639. font-weight: normal;
  640. font-size: 14px;
  641. color: rgba(255, 255, 255, 0.9);
  642. font-style: normal;
  643. text-transform: none;
  644. margin-top: 6px;
  645. }
  646. .circle {
  647. display: flex;
  648. justify-content: center;
  649. align-items: center;
  650. margin-top: 12px;
  651. width: 48px;
  652. height: 48px;
  653. :deep(.el-progress-circle) {
  654. width: 48px !important;
  655. height: 48px !important;
  656. }
  657. }
  658. }
  659. }
  660. .line {
  661. height: 50px;
  662. width: 2px;
  663. background: linear-gradient(0deg, rgba(34, 73, 127, 0) 0%, rgba(136, 234, 255, 0.6) 50%, rgba(34, 73, 127, 0) 100%);
  664. margin: 0 15px;
  665. }
  666. }
  667. }
  668. .modules_bg_yjcl {
  669. width: 223px;
  670. height: 126px;
  671. padding: 5px 20px 10px;
  672. box-sizing: border-box;
  673. }
  674. }
  675. </style>