detail.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427
  1. <template>
  2. <div class="videoDaysDetail">
  3. <el-dialog
  4. title="录像详情"
  5. :visible.sync="isShow"
  6. width="1200px"
  7. :destroy-on-close="true"
  8. >
  9. <el-descriptions title="基础信息" :column="3">
  10. <el-descriptions-item label="通道名称">{{
  11. data.channelName
  12. }}</el-descriptions-item>
  13. <el-descriptions-item label="监控主机">{{
  14. data.hostName
  15. }}</el-descriptions-item>
  16. <el-descriptions-item label="IP地址">{{
  17. data.channelIp
  18. }}</el-descriptions-item>
  19. <!-- <el-descriptions-item label="组织机构" >{{data.orgName}}</el-descriptions-item>-->
  20. <!-- <el-descriptions-item label="上报时间" >{{data.updateTime}}</el-descriptions-item>-->
  21. <!-- <el-descriptions-item label="监控主机" >{{data.equipmentName}}</el-descriptions-item>-->
  22. <!-- <el-descriptions-item label="摄像头" >{{data.channelName}}</el-descriptions-item>-->
  23. <!-- <el-descriptions-item label="通道号" >{{data.channelCode}}</el-descriptions-item>-->
  24. <!-- <el-descriptions-item label="计划存储天数" >{{data.planDays}}</el-descriptions-item>-->
  25. <!-- <el-descriptions-item label="实际存储天数" >{{data.realDays}}</el-descriptions-item>-->
  26. <!-- <el-descriptions-item label="计划录像开始时间" >{{data.planStartTime}}</el-descriptions-item>-->
  27. <!-- <el-descriptions-item label="计划录像结束时间" >{{data.planEndTime}}</el-descriptions-item>-->
  28. </el-descriptions>
  29. <el-descriptions
  30. title="录像质量"
  31. :column="3"
  32. v-if="data.quality == null || data.quality.state == null"
  33. >
  34. <el-descriptions-item label="检测结果"> 未知 </el-descriptions-item>
  35. </el-descriptions>
  36. <div v-else>
  37. <el-descriptions title="录像质量" :column="3">
  38. <el-descriptions-item label="检测结果">{{
  39. data.quality.state == 1 ? "异常" : "正常"
  40. }}</el-descriptions-item>
  41. <el-descriptions-item label="更新时间">{{
  42. dayjs(data.quality.updateTime).format("YYYY年M月D日H时m分")
  43. }}</el-descriptions-item>
  44. </el-descriptions>
  45. <el-descriptions :column="1" v-if="data.quality.quality == 1">
  46. <el-descriptions-item label="诊断截图">
  47. <div>
  48. <ul class="legend-box">
  49. <li>
  50. <el-tag
  51. size="small"
  52. type="warning"
  53. v-if="data.quality.signalLost"
  54. >视频信号</el-tag
  55. >
  56. </li>
  57. <li>
  58. <el-tag
  59. size="small"
  60. type="warning"
  61. v-if="data.quality.occlude"
  62. >遮挡</el-tag
  63. >
  64. </li>
  65. <li>
  66. <el-tag size="small" type="warning" v-if="data.quality.blurry"
  67. >模糊</el-tag
  68. >
  69. </li>
  70. <li>
  71. <el-tag
  72. size="small"
  73. type="warning"
  74. v-if="data.quality.colorCast"
  75. >偏色</el-tag
  76. >
  77. </li>
  78. <li>
  79. <el-tag
  80. size="small"
  81. type="warning"
  82. v-if="data.quality.snowflake"
  83. >雪花</el-tag
  84. >
  85. </li>
  86. <li>
  87. <el-tag size="small" type="warning" v-if="data.quality.stripe"
  88. >条纹</el-tag
  89. >
  90. </li>
  91. <li>
  92. <el-tag
  93. size="small"
  94. type="warning"
  95. v-if="data.quality.contrast"
  96. >对比度</el-tag
  97. >
  98. </li>
  99. <li>
  100. <el-tag
  101. size="small"
  102. type="warning"
  103. v-if="data.quality.brightness"
  104. >亮度</el-tag
  105. >
  106. </li>
  107. </ul>
  108. <div
  109. style="
  110. display: block;
  111. width: 300px;
  112. max-height: 300px;
  113. margin-top: 20px;
  114. "
  115. >
  116. -->
  117. <el-image
  118. :src="data.quality.image"
  119. :preview-src-list="[data.quality.image]"
  120. >
  121. <div slot="error" class="image-slot">
  122. <i class="el-icon-picture-outline"></i>
  123. </div>
  124. </el-image>
  125. </div>
  126. </div>
  127. </el-descriptions-item>
  128. </el-descriptions>
  129. </div>
  130. <el-descriptions
  131. title="录像完整性"
  132. :column="3"
  133. v-if="data.integrity == null || data.integrity.state == null"
  134. >
  135. <el-descriptions-item label="检测结果"> 未知 </el-descriptions-item>
  136. </el-descriptions>
  137. <div v-else>
  138. <el-descriptions title="录像完整性" :column="3">
  139. <el-descriptions-item label="检测结果">{{
  140. data.integrity.state == 1 ? "异常" : "正常"
  141. }}</el-descriptions-item>
  142. <el-descriptions-item label="录像日期">{{
  143. dayjs(data.integrity.recordDate).format("YYYY年M月D日")
  144. }}</el-descriptions-item>
  145. <el-descriptions-item label="丢失时长">{{
  146. data.integrity.loseDuration == 0
  147. ? "未丢失"
  148. : data.integrity.loseDuration + "分钟"
  149. }}</el-descriptions-item>
  150. <el-descriptions-item label="更新时间">{{
  151. dayjs(data.integrity.updateTime).format("YYYY年M月D日H时m分")
  152. }}</el-descriptions-item>
  153. </el-descriptions>
  154. <el-descriptions :column="1">
  155. <el-descriptions-item label="丢失时段">
  156. <!-- <time-line></time-line>-->
  157. <ul class="legend-box">
  158. <li>
  159. <i class="legend" style="background-color: #00b2ff"></i>
  160. <span>计划时长</span>
  161. </li>
  162. <li>
  163. <i class="legend" style="background-color: green"></i>
  164. <span>有录像</span>
  165. </li>
  166. <li>
  167. <i class="legend" style="background-color: red"></i>
  168. <span>无录像</span>
  169. </li>
  170. <li>
  171. <i class="legend" style="background-color: #aaa"></i>
  172. <span>未知</span>
  173. </li>
  174. </ul>
  175. </el-descriptions-item>
  176. </el-descriptions>
  177. <div class="time-line-box">
  178. <!-- <div style="width: 100%;height: 20px;background-color: red; "></div>-->
  179. <progress-bar
  180. :timeCell="timeCells"
  181. :videoData="playVideoObj"
  182. :startTime="start_timestamp"
  183. ></progress-bar>
  184. </div>
  185. <div class="time-line">
  186. <el-timeline :reverse="false">
  187. <el-timeline-item
  188. v-for="(activity, index) in data.loseDateList"
  189. :key="index"
  190. color="rgb(208 230 253)"
  191. size="large"
  192. type="primary"
  193. >
  194. <div class="time">
  195. <div>
  196. <span class="year">
  197. {{ activity.month }}
  198. </span>
  199. </div>
  200. <!-- <div class="day">{{ activity.time.substring(0, 4) }}年</div> -->
  201. </div>
  202. <div class="ml10">
  203. <el-tag
  204. v-for="(date, number) in activity.lostDates"
  205. :key="number"
  206. >
  207. <div>
  208. {{ date }}
  209. <div class="reTip"></div>
  210. </div>
  211. </el-tag>
  212. </div>
  213. </el-timeline-item>
  214. </el-timeline>
  215. </div>
  216. </div>
  217. <el-descriptions
  218. title="录像存储"
  219. :column="3"
  220. v-if="data.storage == null || data.storage.planDays == null"
  221. >
  222. <el-descriptions-item label="存储状态"> 未知 </el-descriptions-item>
  223. </el-descriptions>
  224. <div v-else>
  225. <el-descriptions title="录像存储" :column="3">
  226. <el-descriptions-item label="计划存储"
  227. >{{ data.storage.planDays }}天</el-descriptions-item
  228. >
  229. <el-descriptions-item label="实际存储"
  230. >{{ data.storage.realDays }}天</el-descriptions-item
  231. >
  232. <el-descriptions-item label="最早录像存储日期"
  233. >dayjs(data.storage.earliestTime).format("YYYY年M月D日")</el-descriptions-item
  234. >
  235. </el-descriptions>
  236. <el-descriptions :column="1">
  237. <el-descriptions-item label="存储状态">
  238. <!-- <time-line></time-line>-->
  239. <ul class="legend-box">
  240. <li>
  241. <i class="legend" style="background-color: green"></i>
  242. <span>录像完整</span>
  243. </li>
  244. <li>
  245. <i class="legend" style="background-color: orange"></i>
  246. <span>部分丢失</span>
  247. </li>
  248. <li>
  249. <i class="legend" style="background-color: red"></i>
  250. <span>全部丢失</span>
  251. </li>
  252. <li>
  253. <i class="legend" style="background-color: #cbd5e0"></i>
  254. <span>计划录像天数</span>
  255. </li>
  256. </ul>
  257. </el-descriptions-item>
  258. </el-descriptions>
  259. <div class="calendar-box">
  260. <Calendar
  261. :startDate="data.storage.earliestTime"
  262. :full="data.storage.fullDates"
  263. :paritialLoss="data.storage.partialLossDates"
  264. :allLoss="data.storage.allLostDates"
  265. ></Calendar>
  266. </div>
  267. </div>
  268. <div slot="footer" class="dialog-footer">
  269. <el-button @click="onHide">关闭</el-button>
  270. </div>
  271. </el-dialog>
  272. </div>
  273. </template>
  274. <script>
  275. import TimeLine from "./timeLine.vue";
  276. import ProgressBar from "./ProgressBar";
  277. import Calendar from "./Calendar.vue";
  278. import dayjs from "dayjs";
  279. import { detail } from "@/api/iot/videoDiagnosis.js";
  280. export default {
  281. components: { TimeLine, ProgressBar, Calendar },
  282. data() {
  283. return {
  284. src: "https://cube.elemecdn.com/6/94/4d3ea53c084bad6931a56d5158a48jpeg.jpeg",
  285. isShow: false,
  286. data: {},
  287. id: null,
  288. playVideoObj: {}, //选中的正在播放的录像
  289. timeCells: [], //录像时间块
  290. start_timestamp: new Date().getTime() - 5 * 60 * 60 * 1000, //刻度轴开始时间
  291. };
  292. },
  293. methods: {
  294. dayjs,
  295. async show(hostCode, channelCode) {
  296. this.data = await detail(hostCode, channelCode);
  297. this.isShow = true;
  298. },
  299. onHide() {
  300. this.isShow = false;
  301. },
  302. },
  303. };
  304. </script>
  305. <style lang="scss">
  306. .videoDaysDetail {
  307. .block {
  308. display: block;
  309. }
  310. .time-line {
  311. margin-top: 10px;
  312. margin-left: 80px;
  313. }
  314. .list-title {
  315. font-size: 16px;
  316. font-family: PingFangSC-Medium, PingFang SC;
  317. font-weight: 500;
  318. color: #181b1e;
  319. }
  320. .list-company {
  321. font-size: 14px;
  322. font-family: PingFangSC-Regular, PingFang SC;
  323. font-weight: 400;
  324. color: #2991ff;
  325. margin-top: 15px;
  326. margin-bottom: 15px;
  327. }
  328. .list-desc {
  329. font-size: 14px;
  330. font-family: PingFangSC-Regular, PingFang SC;
  331. font-weight: 400;
  332. color: #596878;
  333. }
  334. .el-tag--small {
  335. margin-bottom: 10px;
  336. }
  337. .reTip {
  338. display: block;
  339. background: #f00;
  340. border-radius: 50%;
  341. width: 4px;
  342. height: 4px;
  343. top: -21px;
  344. right: -26px;
  345. position: relative;
  346. z-index: 4;
  347. }
  348. //左侧时间
  349. .time {
  350. color: rgb(181 215 251);
  351. position: absolute;
  352. left: -35px;
  353. top: -1px;
  354. .year {
  355. font-size: 14px;
  356. font-family: PingFangSC-Regular, PingFang SC;
  357. font-weight: 400;
  358. color: #20354a;
  359. }
  360. .day {
  361. font-size: 14px;
  362. font-family: PingFangSC-Regular, PingFang SC;
  363. font-weight: 400;
  364. color: #596878;
  365. text-align: center;
  366. margin-top: 10px;
  367. }
  368. }
  369. .legend-box {
  370. display: flex;
  371. flex-direction: row;
  372. justify-content: flex-start;
  373. align-items: center;
  374. > li {
  375. display: flex;
  376. flex-direction: row;
  377. justify-content: flex-start;
  378. align-items: center;
  379. margin-right: 20px;
  380. i {
  381. margin-right: 5px;
  382. }
  383. }
  384. }
  385. .time-line-box {
  386. width: 100%;
  387. padding: 0 80px 50px 80px;
  388. }
  389. .calendar-box {
  390. width: 100%;
  391. display: flex;
  392. flex-wrap: wrap;
  393. justify-content: space-between;
  394. //>div{
  395. // width: 30%;
  396. //}
  397. }
  398. .el-calendar-table .el-calendar-day {
  399. padding: 5px;
  400. height: auto;
  401. }
  402. .el-calendar__button-group {
  403. display: none;
  404. }
  405. .legend {
  406. display: block;
  407. width: 14px;
  408. height: 10px;
  409. margin-right: 5px;
  410. }
  411. }
  412. </style>