center-area-green.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. <template>
  2. <div class="center-area-green">
  3. <div class="container">
  4. <div class="risk-score">
  5. <div class="item-label">风险得分</div>
  6. <div class="item-val">{{ paramDatas.riskLevel !== undefined && paramDatas.riskLevel !== null ?
  7. paramDatas.riskLevel
  8. : '-' }}</div>
  9. </div>
  10. <div class="dust-warn">
  11. <div class="dust-icon"></div>
  12. <div class="item-content">
  13. <div class="ite-label">粉尘监测预警</div>
  14. <div class="ite-val">{{ paramDatas.fc == 0
  15. ? '低风险'
  16. : paramDatas.fc == 101
  17. ? '低风险'
  18. : paramDatas.fc == 102
  19. ? '一般风险'
  20. : paramDatas.fc == 103
  21. ? '较大风险'
  22. : paramDatas.fc == 104
  23. ? '重大风险'
  24. : paramDatas.fc == 201
  25. ? '报警'
  26. : paramDatas.fc }}</div>
  27. </div>
  28. </div>
  29. <div class="vent-warn">
  30. <div class="vent-icon"></div>
  31. <div class="item-content">
  32. <div class="ite-label">通风监测预警</div>
  33. <div class="ite-val">{{ paramDatas.tf == 0
  34. ? '低风险'
  35. : paramDatas.tf == 101
  36. ? '低风险'
  37. : paramDatas.tf == 102
  38. ? '一般风险'
  39. : paramDatas.tf == 103
  40. ? '较大风险'
  41. : paramDatas.tf == 104
  42. ? '重大风险'
  43. : paramDatas.tf == 201
  44. ? '报警'
  45. : paramDatas.tf }}</div>
  46. </div>
  47. </div>
  48. <div class="gas-warn">
  49. <div class="gas-icon"></div>
  50. <div class="item-content1">
  51. <div class="ite-content">
  52. <div class="ite-label">瓦斯监测预警</div>
  53. <div class="ite-val">{{ paramDatas.ws == 0
  54. ? '低风险'
  55. : paramDatas.ws == 101
  56. ? '低风险'
  57. : paramDatas.ws == 102
  58. ? '一般风险'
  59. : paramDatas.ws == 103
  60. ? '较大风险'
  61. : paramDatas.ws == 104
  62. ? '重大风险'
  63. : paramDatas.ws == 201
  64. ? '报警'
  65. : paramDatas.ws }}</div>
  66. </div>
  67. <div class="ite-content">
  68. <div class="ite-label">矿井瓦斯等级鉴定</div>
  69. <div class="ite-val">{{ sysOrgCode == 'sdmtjtbdmk' ? '高瓦斯' : '低瓦斯' }}</div>
  70. </div>
  71. </div>
  72. </div>
  73. <div class="device-warn">
  74. <div class="device-icon"></div>
  75. <div class="item-content">
  76. <div class="ite-label">设备监测预警</div>
  77. <div class="ite-val">{{ paramDatas.sb == 0
  78. ? '低风险'
  79. : paramDatas.sb == 101
  80. ? '低风险'
  81. : paramDatas.sb == 102
  82. ? '一般风险'
  83. : paramDatas.sb == 103
  84. ? '较大风险'
  85. : paramDatas.sb == 104
  86. ? '重大风险'
  87. : paramDatas.sb == 201
  88. ? '报警'
  89. : paramDatas.sb }}</div>
  90. </div>
  91. </div>
  92. <div class="fire-warn">
  93. <div class="fire-icon"></div>
  94. <div class="item-content">
  95. <div class="ite-label">火灾监测预警</div>
  96. <div class="ite-val">{{ paramDatas.fire == 0
  97. ? '低风险'
  98. : paramDatas.fire == 101
  99. ? '低风险'
  100. : paramDatas.fire == 102
  101. ? '一般风险'
  102. : paramDatas.fire == 103
  103. ? '较大风险'
  104. : paramDatas.fire == 104
  105. ? '重大风险'
  106. : paramDatas.fire == 201
  107. ? '报警'
  108. : paramDatas.fire }}</div>
  109. </div>
  110. </div>
  111. <div class="db-warn">
  112. <div class="db-icon"></div>
  113. <div class="item-content">
  114. <div class="ite-label">顶板</div>
  115. <div class="ite-val">低风险</div>
  116. </div>
  117. </div>
  118. <div class="sz-warn">
  119. <div class="sz-icon"></div>
  120. <div class="item-content">
  121. <div class="ite-label">水灾</div>
  122. <div class="ite-val">低风险</div>
  123. </div>
  124. </div>
  125. <div class="risk-echartbox">
  126. <RiskWarnLevel :echartData="paramDatas.riskData"></RiskWarnLevel>
  127. </div>
  128. </div>
  129. </div>
  130. </template>
  131. <script lang="ts" setup>
  132. import { reactive, watch } from 'vue'
  133. import { useGlobSetting } from '/@/hooks/setting';
  134. import RiskWarnLevel from './dz-risk.vue'
  135. let props = defineProps({
  136. paramData: {
  137. type: Object,
  138. default: () => {
  139. return {}
  140. }
  141. }
  142. })
  143. let paramDatas = reactive<any>({})
  144. const { sysOrgCode, sysDataType } = useGlobSetting();
  145. watch(() => props.paramData, (newV, oldV) => {
  146. paramDatas = newV
  147. }, { immediate: true, deep: true })
  148. </script>
  149. <style lang="less" scoped>
  150. @import '/@/design/theme.less';
  151. @{theme-deepblue} {
  152. .center-area-green {
  153. --image-model_container_img: url('@/assets/images/themify/deepblue/home-container/configurable/1-1.png');
  154. --image-model_risk_score: url('@/assets/images/themify/deepblue/home-container/configurable/1-2.png');
  155. --image-model_dust_warn: url('@/assets/images/themify/deepblue/home-container/configurable/1-7.png');
  156. --image-model_vent_warn: url('@/assets/images/themify/deepblue/home-container/configurable/1-5.png');
  157. --image-model_gas_warn: url('@/assets/images/themify/deepblue/home-container/configurable/1-3.png');
  158. --image-model_device_warn: url('@/assets/images/themify/deepblue/home-container/configurable/1-6.png');
  159. --image-model_fire_warn: url('@/assets/images/themify/deepblue/home-container/configurable/1-4.png');
  160. --image-model_db_warn: url('@/assets/images/themify/deepblue/home-container/configurable/db-green.png');
  161. --image-model_sz_warn: url('@/assets/images/themify/deepblue/home-container/configurable/sz-green.png');
  162. --image-model_item_content: url('@/assets/images/themify/deepblue/home-container/configurable/1-8.png');
  163. --image-model_item_content1: url('@/assets/images/themify/deepblue/home-container/configurable/1-9.png');
  164. }
  165. }
  166. .center-area-green {
  167. --image-model_container_img: url('@/assets/images/home-green/1-1.png');
  168. --image-model_risk_score: url('@/assets/images/home-green/1-2.png');
  169. --image-model_dust_warn: url('@/assets/images/home-green/1-7.png');
  170. --image-model_vent_warn: url('@/assets/images/home-green/1-5.png');
  171. --image-model_gas_warn: url('@/assets/images/home-green/1-3.png');
  172. --image-model_device_warn: url('@/assets/images/home-green/1-6.png');
  173. --image-model_fire_warn: url('@/assets/images/home-green/1-4.png');
  174. --image-model_db_warn: url('@/assets/images/home-green/db-green.png');
  175. --image-model_sz_warn: url('@/assets/images/home-green/sz-green.png');
  176. --image-model_item_content: url('@/assets/images/home-green/1-8.png');
  177. --image-model_item_content1: url('@/assets/images/home-green/1-9.png');
  178. height: 100%;
  179. .container {
  180. position: relative;
  181. width: 100%;
  182. height: calc(100% - 30px);
  183. margin-top: 30px;
  184. background: var(--image-model_container_img) no-repeat center;
  185. background-size: 100% 100%;
  186. }
  187. .risk-echartbox {
  188. position: absolute;
  189. left: 18px;
  190. top: -52px;
  191. width: 220px;
  192. height: 170px;
  193. }
  194. .risk-score {
  195. position: absolute;
  196. left: 50%;
  197. top: -46px;
  198. transform: translate(-44%, 0);
  199. width: 206px;
  200. height: 60px;
  201. font-size: 18px;
  202. color: #fff;
  203. background: var(--image-model_risk_score) no-repeat;
  204. background-size: 100% 100%;
  205. .item-label {
  206. text-align: center;
  207. margin-bottom: 5px;
  208. }
  209. .item-val {
  210. text-align: center;
  211. font-family: 'douyuFont';
  212. }
  213. }
  214. .dust-warn {
  215. position: absolute;
  216. left: 242px;
  217. top: 52px;
  218. width: 132px;
  219. height: 108px;
  220. background: var(--image-model_dust_warn) no-repeat;
  221. background-size: 100% 100%;
  222. }
  223. .vent-warn {
  224. position: absolute;
  225. left: 200px;
  226. top: 334px;
  227. width: 132px;
  228. height: 108px;
  229. background: var(--image-model_vent_warn) no-repeat;
  230. background-size: 100% 100%;
  231. }
  232. .gas-warn {
  233. position: absolute;
  234. left: 414px;
  235. top: 416px;
  236. width: 132px;
  237. height: 108px;
  238. background: var(--image-model_gas_warn) no-repeat;
  239. background-size: 100% 100%;
  240. }
  241. .device-warn {
  242. position: absolute;
  243. right: 196px;
  244. top: 340px;
  245. width: 132px;
  246. height: 108px;
  247. background: var(--image-model_device_warn) no-repeat;
  248. background-size: 100% 100%;
  249. }
  250. .fire-warn {
  251. position: absolute;
  252. right: 142px;
  253. top: 58px;
  254. width: 132px;
  255. height: 108px;
  256. background: var(--image-model_fire_warn) no-repeat;
  257. background-size: 100% 100%;
  258. }
  259. .db-warn {
  260. position: absolute;
  261. left: 42px;
  262. top: 182px;
  263. width: 132px;
  264. height: 108px;
  265. background: var(--image-model_db_warn) no-repeat;
  266. background-size: 100% 100%;
  267. }
  268. .sz-warn {
  269. position: absolute;
  270. right: -2px;
  271. top: 136px;
  272. width: 132px;
  273. height: 108px;
  274. background: var(--image-model_sz_warn) no-repeat;
  275. background-size: 100% 100%;
  276. }
  277. .item-content {
  278. position: absolute;
  279. left: -4px;
  280. top: -54px;
  281. width: 127px;
  282. height: 56px;
  283. background: var(--image-model_item_content) no-repeat;
  284. background-size: 100% 100%;
  285. }
  286. .item-content1 {
  287. display: flex;
  288. position: absolute;
  289. left: -60px;
  290. top: -54px;
  291. width: 258px;
  292. height: 56px;
  293. background: var(--image-model_item_content1) no-repeat;
  294. background-size: 100% 100%;
  295. }
  296. .ite-label {
  297. text-align: center;
  298. margin-bottom: 10px;
  299. padding-top: 4px;
  300. font-size: 12px;
  301. }
  302. .ite-val {
  303. width: 100%;
  304. text-align: center;
  305. font-family: 'douyuFont';
  306. font-size: 12px;
  307. }
  308. .ite-content {
  309. width: 50%;
  310. height: 100%;
  311. }
  312. }
  313. </style>