infotrack2.vue 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573
  1. <template>
  2. <div class="track-info">
  3. <div class="form-info">
  4. <div class="work-flow">
  5. <div class="work-flow-line"></div>
  6. <div class="work-flow-item">
  7. <div class="work-flow-icon-item">
  8. <div class="work-flow-icon-o"></div>
  9. <div class="work-flow-icon-i"></div>
  10. <span class="svg-icon">
  11. <SvgIcon svgid="svg-qx-warn"></SvgIcon>
  12. </span>
  13. </div>
  14. <div class="work-flow-text">流程未启动</div>
  15. </div>
  16. <div class="work-flow-item">
  17. <div class="work-flow-icon-item">
  18. <div class="work-flow-icon-o"></div>
  19. <div class="work-flow-icon-i"></div>
  20. <span class="svg-icon">
  21. <SvgIcon svgid="svg-qx-down"></SvgIcon>
  22. </span>
  23. </div>
  24. <div class="work-flow-text">消缺单已下达</div>
  25. </div>
  26. <div class="work-flow-item">
  27. <div class="work-flow-icon-item">
  28. <div class="work-flow-icon-o"></div>
  29. <div class="work-flow-icon-i"></div>
  30. <span class="svg-icon">
  31. <SvgIcon svgid="svg-qx-hour-hand"></SvgIcon>
  32. </span>
  33. </div>
  34. <div class="work-flow-text">消缺单处理中</div>
  35. </div>
  36. <div class="work-flow-item active">
  37. <div class="work-flow-icon-item">
  38. <div class="work-flow-icon-o"></div>
  39. <div class="work-flow-icon-i"></div>
  40. <span class="svg-icon">
  41. <SvgIcon svgid="svg-对"></SvgIcon>
  42. </span>
  43. </div>
  44. <div class="work-flow-text">消缺完成</div>
  45. </div>
  46. <div class="work-flow-item">
  47. <div class="work-flow-icon-item">
  48. <div class="work-flow-icon-o"></div>
  49. <div class="work-flow-icon-i"></div>
  50. <span class="svg-icon">
  51. <SvgIcon svgid="svg-qx-flag"></SvgIcon>
  52. </span>
  53. </div>
  54. <div class="work-flow-text">消缺验收</div>
  55. </div>
  56. </div>
  57. <div class="form-body">
  58. <el-form ref="form" :model="form" label-width="120px">
  59. <el-row>
  60. <el-col :span="12">
  61. <el-form-item label="风场:">
  62. <el-input
  63. v-model="form.wpName"
  64. placeholder="风场名称"
  65. ></el-input>
  66. </el-form-item>
  67. </el-col>
  68. <el-col :span="12">
  69. <el-form-item label="风机:">
  70. <el-input
  71. v-model="form.wtId"
  72. placeholder="风机名称"
  73. ></el-input>
  74. </el-form-item>
  75. </el-col>
  76. </el-row>
  77. <el-row>
  78. <el-col :span="12">
  79. <el-form-item label="推荐检修时间:">
  80. <el-input
  81. v-model="form.tjss"
  82. placeholder="推荐检修时间"
  83. ></el-input>
  84. <!-- <el-date-picker v-model="form.tjjxsj" type="datetime" placeholder="推荐检修时间" popper-class="date-select"></el-date-picker> -->
  85. </el-form-item>
  86. </el-col>
  87. <el-col :span="12">
  88. <el-form-item label="预计检修风速:">
  89. <el-input
  90. v-model="form.tjfs"
  91. placeholder="预计检修风速"
  92. ></el-input>
  93. </el-form-item>
  94. </el-col>
  95. </el-row>
  96. <el-row>
  97. <el-col :span="24">
  98. <el-form-item label="推荐理由:">
  99. <el-input
  100. type="textarea"
  101. :rows="3"
  102. v-model="form.description"
  103. placeholder="推荐理由"
  104. ></el-input>
  105. </el-form-item>
  106. </el-col>
  107. </el-row>
  108. <el-row>
  109. <el-col :span="12">
  110. <el-form-item label="下单时间:">
  111. <el-input
  112. v-model="form.prodtdepttime"
  113. placeholder="下单时间"
  114. ></el-input>
  115. </el-form-item>
  116. </el-col>
  117. <el-col :span="12">
  118. <el-form-item label="主要负责人:">
  119. <el-input
  120. v-model="form.workleader"
  121. placeholder="主要负责人"
  122. ></el-input>
  123. </el-form-item>
  124. </el-col>
  125. </el-row>
  126. <el-row>
  127. <el-col :span="12">
  128. <el-form-item label="出发时间:">
  129. <el-input
  130. v-model="form.departuretime"
  131. placeholder="出发时间"
  132. ></el-input>
  133. </el-form-item>
  134. </el-col>
  135. <el-col :span="12">
  136. <el-form-item label="到达时间:">
  137. <el-input
  138. v-model="form.arrivaltime"
  139. placeholder="到达时间"
  140. ></el-input>
  141. </el-form-item>
  142. </el-col>
  143. </el-row>
  144. <el-row>
  145. <el-col :span="24">
  146. <el-form-item label="排查方法:">
  147. <el-input
  148. type="textarea"
  149. :rows="3"
  150. v-model="form.gzpc"
  151. placeholder="排查方法"
  152. ></el-input>
  153. </el-form-item>
  154. </el-col>
  155. </el-row>
  156. <el-row>
  157. <el-col :span="24">
  158. <el-form-item label="处理方法:">
  159. <el-input
  160. type="textarea"
  161. :rows="3"
  162. v-model="form.repairedcomment"
  163. placeholder="处理方法"
  164. ></el-input>
  165. </el-form-item>
  166. </el-col>
  167. </el-row>
  168. <el-row>
  169. <el-col :span="12">
  170. <el-form-item label="消缺时间:">
  171. <el-input
  172. v-model="form.repairedtime"
  173. placeholder="消缺时间"
  174. ></el-input>
  175. </el-form-item>
  176. </el-col>
  177. <el-col :span="12">
  178. <el-form-item label="故障时长:">
  179. <el-input
  180. v-model="form.degradebugtype"
  181. placeholder="故障时长"
  182. ></el-input>
  183. </el-form-item>
  184. </el-col>
  185. </el-row>
  186. <el-row>
  187. <el-col :span="12">
  188. <el-form-item label="验收人:">
  189. <el-input
  190. v-model="form.checkdeptlabornum"
  191. placeholder="验收人"
  192. ></el-input>
  193. </el-form-item>
  194. </el-col>
  195. <el-col :span="12">
  196. <el-form-item label="验收时间:">
  197. <el-input
  198. v-model="form.checktime"
  199. placeholder="验收时间"
  200. ></el-input>
  201. </el-form-item>
  202. </el-col>
  203. </el-row>
  204. <el-row>
  205. <el-col :span="24">
  206. <el-form-item label="验收意见:">
  207. <el-input
  208. type="textarea"
  209. :rows="3"
  210. v-model="form.checkdeptopinion"
  211. placeholder="验收意见"
  212. ></el-input>
  213. </el-form-item>
  214. </el-col>
  215. </el-row>
  216. </el-form>
  217. </div>
  218. </div>
  219. <div class="evaluate">
  220. <div class="white">评价</div>
  221. <div class="evaluate-item">
  222. <div class="evaluate-label">任务分配时长</div>
  223. <el-input-number class="input-number" v-model="form.rwfpsc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  224. <div class="evaluate-unit">min</div>
  225. </div>
  226. <div class="evaluate-item">
  227. <div class="evaluate-label">任务分配平均时长</div>
  228. <el-input-number class="input-number" v-model="form.rwfppjsc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  229. <div class="evaluate-unit">min</div>
  230. </div>
  231. <div class="evaluate-item">
  232. <div class="evaluate-label">到达现场时长</div>
  233. <el-input-number class="input-number" v-model="form.ddxcsc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  234. <div class="evaluate-unit">min</div>
  235. </div>
  236. <div class="evaluate-item">
  237. <div class="evaluate-label">到达现场平均时长</div>
  238. <el-input-number class="input-number" v-model="form.ddxcpjsc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  239. <div class="evaluate-unit">min</div>
  240. </div>
  241. <div class="evaluate-item">
  242. <div class="evaluate-label">缺陷处理时长</div>
  243. <el-input-number class="input-number" v-model="form.qxclsc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  244. <div class="evaluate-unit">min</div>
  245. </div>
  246. <div class="evaluate-item">
  247. <div class="evaluate-label">缺陷处理平均时长</div>
  248. <el-input-number class="input-number" v-model="form.qxclpjsc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  249. <div class="evaluate-unit">min</div>
  250. </div>
  251. <div class="evaluate-item">
  252. <div class="evaluate-label">验收时长</div>
  253. <el-input-number class="input-number" v-model="form.yssc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  254. <div class="evaluate-unit">min</div>
  255. </div>
  256. <div class="evaluate-item">
  257. <div class="evaluate-label">验收平均时长</div>
  258. <el-input-number class="input-number" v-model="form.yspjsc" :controls="false" controls-position="right" :min="0" :max="1000"></el-input-number>
  259. <div class="evaluate-unit">min</div>
  260. </div>
  261. </div>
  262. <div class="tabs">
  263. <div class="tab-box">
  264. <div class="tab-item" v-for="(tab, index) of tabs" :key="index" :class="{ active: activeTab == index }" @click="selectTab(index)">
  265. <span class="svg-icon svg-icon-md" :class="activeTab == index ? 'svg-icon-green' : 'svg-icon-write'">
  266. <SvgIcon :svgid="tab.icon"></SvgIcon>
  267. </span>
  268. <span>{{ tab.text }}</span>
  269. </div>
  270. </div>
  271. </div>
  272. </div>
  273. </template>
  274. <script>
  275. import SvgIcon from "@com/coms/icon/svg-icon.vue";
  276. export default {
  277. components: {
  278. SvgIcon
  279. },
  280. props: {
  281. data: Object,
  282. },
  283. data() {
  284. return {
  285. tabs: [
  286. {
  287. icon: "svg-gis",
  288. text: "GIS地貌",
  289. },
  290. {
  291. icon: "svg-jkp",
  292. text: "手环监控",
  293. },
  294. {
  295. icon: "svg-jk",
  296. text: "监控视频",
  297. },
  298. ],
  299. activeTab: 0,
  300. form: {
  301. wtId: "",
  302. wpId: "",
  303. wpName: "",
  304. tjyy: "",
  305. tjss: null,
  306. tjfs: null,
  307. bugnum: null,
  308. workgroup1: null,
  309. findlabornum: null,
  310. reportlabornum: null,
  311. description: null,
  312. departuretime: null,
  313. arrivaltime: null,
  314. prodtdeptopinion: null,
  315. workleader: null,
  316. repairedtime: null,
  317. repairedcomment: null,
  318. unresolvedbug: null,
  319. checktime: null,
  320. degradebugtype: null,
  321. repairdeptbugtype1: null,
  322. checkdeptlabornum: null,
  323. status: null,
  324. gzpc: null,
  325. gzjx: null,
  326. prodtdepttime: null,
  327. checkdeptopinion: null,
  328. rwfpsc: 0.0,
  329. rwfppjsc: 1066.0,
  330. ddxcsc: 0.0,
  331. ddxcpjsc: 0.0,
  332. qxclsc: 0.0,
  333. qxclpjsc: 0.0,
  334. yssc: 0.0,
  335. yspjsc: 0.0,
  336. workHours: null,
  337. rwfpsc: 0,
  338. rwfppjsc: 0,
  339. ddxcsc: 0,
  340. ddxcpjsc: 0,
  341. qxclsc: 0,
  342. qxclpjsc: 0,
  343. yssc: 0,
  344. yspjsc: 0,
  345. workHours: 0
  346. },
  347. };
  348. },
  349. mounted() {
  350. this.$nextTick(() => {
  351. this.form = this.data;
  352. });
  353. },
  354. // 函数
  355. methods: {
  356. selectTab: function (index) {
  357. this.activeTab = index;
  358. },
  359. },
  360. watch: {
  361. data(value) {
  362. this.form = value;
  363. this.form.tjss = value.tjss?new Date(value.tjss).formatDate("yyyy-MM-dd hh:mm:ss"):""
  364. this.form.prodtdepttime = value.prodtdepttime?new Date(value.prodtdepttime).formatDate("yyyy-MM-dd hh:mm:ss"):""
  365. this.form.departuretime = value.departuretime?new Date(value.departuretime).formatDate("yyyy-MM-dd hh:mm:ss"):""
  366. this.form.arrivaltime = value.arrivaltime?new Date(value.arrivaltime).formatDate("yyyy-MM-dd hh:mm:ss"):""
  367. this.form.repairedtime = value.repairedtime?new Date(value.repairedtime).formatDate("yyyy-MM-dd hh:mm:ss"):""
  368. this.form.checktime = value.checktime?new Date(value.checktime).formatDate("yyyy-MM-dd hh:mm:ss"):""
  369. },
  370. },
  371. };
  372. </script>
  373. <style lang="less">
  374. .track-info {
  375. display: flex;
  376. .form-info {
  377. flex: 0 0 720px;
  378. .work-flow {
  379. height: 132px;
  380. width: 100%;
  381. background: fade(@gray, 20);
  382. margin-bottom: 8px;
  383. padding: 26px 69px;
  384. display: flex;
  385. position: relative;
  386. .work-flow-line {
  387. position: absolute;
  388. width: 600px;
  389. height: 4px;
  390. left: calc(50% - 300px);
  391. top: calc(50% - 11px);
  392. background: @green;
  393. }
  394. .work-flow-item {
  395. flex: 1;
  396. display: flex;
  397. flex-direction: column;
  398. align-items: center;
  399. justify-content: center;
  400. &.active {
  401. .work-flow-icon-item {
  402. .work-flow-icon-o {
  403. border: 1px solid @green;
  404. opacity: 0.4;
  405. }
  406. .work-flow-icon-i {
  407. border: 2px solid @green;
  408. background: linear-gradient(to bottom, #1F2B2B 0%,#1F2B2B 20%,@green 100%);
  409. }
  410. .svg-icon {
  411. svg {
  412. use {
  413. fill: @green;
  414. }
  415. }
  416. }
  417. }
  418. .work-flow-text {
  419. color: @green;
  420. }
  421. }
  422. .work-flow-icon-item {
  423. width: 60px;
  424. height: 60px;
  425. position: relative;
  426. .work-flow-icon-o {
  427. position: absolute;
  428. top: 0;
  429. left: 0;
  430. width: 60px;
  431. height: 60px;
  432. border-radius: 50%;
  433. border: 1px solid #B3BDC0;
  434. opacity: 0.4;
  435. }
  436. .work-flow-icon-m {
  437. position: absolute;
  438. top: 1px;
  439. left: 1px;
  440. width: 59px;
  441. height: 59px;
  442. border-radius: 50%;
  443. border: 4px solid #212b2b;
  444. }
  445. .work-flow-icon-i {
  446. position: absolute;
  447. top: 5px;
  448. left: 5px;
  449. width: 50px;
  450. height: 50px;
  451. border-radius: 50%;
  452. border: 2px solid #606769;
  453. background: linear-gradient(to bottom, #1F2B2B 0%,#1F2B2B 20%,#606769 100%);
  454. }
  455. .svg-icon {
  456. position: absolute;
  457. width: 26px;
  458. height: 26px;
  459. top: calc(50% - 10px);
  460. left: calc(50% - 13px);
  461. svg {
  462. width: 26px;
  463. height: 26px;
  464. use {
  465. fill: @gray-l;
  466. }
  467. }
  468. }
  469. }
  470. .work-flow-text {
  471. color: @gray-l;
  472. margin-top: 8px;
  473. font-size: @fontsize-s;
  474. }
  475. }
  476. }
  477. }
  478. .evaluate {
  479. flex: 0 0 240px;
  480. margin-left: 30px;
  481. .evaluate-item {
  482. display: flex;
  483. align-items: center;
  484. margin-top: 8px;
  485. .evaluate-label {
  486. width: 120px;
  487. text-align: right;
  488. }
  489. .evaluate-label,
  490. .evaluate-unit {
  491. font-size: @fontsize;
  492. color: @gray-l;
  493. }
  494. .input-number {
  495. display: inline-block;
  496. width: 62px;
  497. margin: 0 16px;
  498. }
  499. }
  500. }
  501. .tabs {
  502. flex: 0 0 200px;
  503. height: 619px;
  504. margin-left: 20px;
  505. border-left: 1px solid #53626833;
  506. .tab-box {
  507. margin: 1.852vh 2.778vh;
  508. display: inline-block;
  509. z-index: 2;
  510. position: relative;
  511. margin: 26px 0 0 20px;
  512. .tab-item {
  513. display: flex;
  514. align-items: center;
  515. // justify-content: center;
  516. font-size: @fontsize-l;
  517. cursor: pointer;
  518. // width: 120px;
  519. padding: 8px;
  520. margin-bottom: 16px;
  521. &.active {
  522. color: @green;
  523. position: relative;
  524. background-image: @greenLinearTop;
  525. &::after {
  526. content: "";
  527. position: absolute;
  528. width: 100%;
  529. height: 5px;
  530. border: 1px solid @green;
  531. border-top: 0;
  532. left: 0;
  533. bottom: 0;
  534. box-sizing: border-box;
  535. }
  536. }
  537. .svg-icon {
  538. margin-right: 16px;
  539. }
  540. }
  541. }
  542. }
  543. }
  544. </style>