laboratory.vue 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068
  1. <!-- -->
  2. <template>
  3. <div class="laboratory_box">
  4. <!-- 筛选 -->
  5. <el-row>
  6. <el-col>
  7. <div class="search_box">
  8. <!-- 任务处理人 -->
  9. <el-select
  10. filterable
  11. v-model="input"
  12. clearable
  13. @change="searchData"
  14. placeholder="请选择任务处理人/实际处理人"
  15. size="mini"
  16. >
  17. <el-option
  18. v-for="item in conductorList"
  19. :key="item.value"
  20. :label="item.label"
  21. :value="item.value"
  22. >
  23. </el-option>
  24. </el-select>
  25. <!-- 任务状态 -->
  26. <el-select
  27. filterable
  28. v-model="value"
  29. @change="searchData"
  30. clearable
  31. placeholder="请选择任务状态"
  32. size="mini"
  33. >
  34. <el-option
  35. v-for="item in options"
  36. :key="item.value"
  37. :label="item.label"
  38. :value="item.value"
  39. >
  40. </el-option>
  41. </el-select>
  42. <!-- 时间筛选 -->
  43. <el-date-picker
  44. size="mini"
  45. v-model="value1"
  46. @change="searchData"
  47. type="daterange"
  48. range-separator="至"
  49. start-placeholder="开始日期"
  50. end-placeholder="结束日期"
  51. align="right"
  52. :editable="false"
  53. >
  54. </el-date-picker>
  55. <div class="btn_box">
  56. <el-button type="info" size="mini" @click="searchData"
  57. >搜索</el-button
  58. >
  59. <el-button type="info" size="mini" @click="reset">重置</el-button>
  60. </div>
  61. </div>
  62. </el-col>
  63. </el-row>
  64. <el-card style="margin-top: 15px">
  65. <!-- 列表 -->
  66. <el-table
  67. :data="tableData"
  68. stripe
  69. v-loading="loading"
  70. :height="48 * 13"
  71. style="width: 100%; overflow-y: auto"
  72. >
  73. <el-table-column prop="serial" label="序号" width="100">
  74. <template slot-scope="scope">
  75. <span>{{ (page - 1) * 20 + scope.row.serial }}</span>
  76. </template>
  77. </el-table-column>
  78. <el-table-column prop="trap_number" label="设备编号" width="120">
  79. </el-table-column>
  80. <el-table-column prop="lng" label="经度" width="150">
  81. <template slot-scope="scope">
  82. <span>{{ scope.row.lng || '无' }}</span>
  83. </template>
  84. </el-table-column>
  85. <el-table-column prop="lat" label="纬度" width="150">
  86. <template slot-scope="scope">
  87. <span>{{ scope.row.lat || '无' }}</span>
  88. </template>
  89. </el-table-column>
  90. <el-table-column prop="id" label="任务编号" width="180">
  91. </el-table-column>
  92. <el-table-column
  93. prop="operator_user_name"
  94. label="任务处理人"
  95. width="180"
  96. >
  97. </el-table-column>
  98. <el-table-column
  99. prop="actual_operator_name"
  100. label="实际处理人"
  101. width="180"
  102. >
  103. <template slot-scope="scope">
  104. <span>{{ scope.row.actual_operator_name || '暂无' }}</span>
  105. </template>
  106. </el-table-column>
  107. <el-table-column prop="report_time" label="带回时间">
  108. <template slot-scope="scope">
  109. <span>{{ scope.row.report_time || '暂无' }}</span>
  110. </template>
  111. </el-table-column>
  112. <el-table-column prop="discern_status" label="任务状态" width="280">
  113. <template slot-scope="scope">
  114. <span v-if="scope.row.discern_status == '待接收'">
  115. <span
  116. style="
  117. width: 6px;
  118. height: 6px;
  119. background: #f93f3d;
  120. border-radius: 50%;
  121. display: inline-block;
  122. margin: 0 0 2px 0;
  123. "
  124. ></span>
  125. <span>待接收样本</span>
  126. </span>
  127. <span v-if="scope.row.discern_status == '已接收'">
  128. <span
  129. style="
  130. width: 6px;
  131. height: 6px;
  132. background: #f93f3d;
  133. border-radius: 50%;
  134. display: inline-block;
  135. margin: 0 0 2px 0;
  136. "
  137. ></span>
  138. <span>已接收样本</span>
  139. </span>
  140. <span v-if="scope.row.discern_status == '已填报'">
  141. <span
  142. style="
  143. width: 6px;
  144. height: 6px;
  145. background: #e6a23c;
  146. border-radius: 50%;
  147. display: inline-block;
  148. margin: 0 0 2px 0;
  149. "
  150. ></span>
  151. <span>已填报样本</span>
  152. </span>
  153. </template>
  154. </el-table-column>
  155. <el-table-column label="操作" fixed="right">
  156. <template slot-scope="scope">
  157. <a
  158. v-if="scope.row.discern_status == '待接收'"
  159. class="reset"
  160. href="javascript:;"
  161. @click="receive(scope.row)"
  162. >确认接收</a
  163. >
  164. <a
  165. v-if="scope.row.discern_status == '已接收'"
  166. class="reset"
  167. @click="examine(scope.row)"
  168. href="javascript:;"
  169. >填报</a
  170. >
  171. <a
  172. v-if="scope.row.discern_status == '已填报'"
  173. class="reset"
  174. href="javascript:;"
  175. @click="examine(scope.row)"
  176. >编辑</a
  177. >
  178. </template>
  179. </el-table-column>
  180. </el-table>
  181. <!-- 分页 -->
  182. <el-pagination
  183. style="margin: 60px 0 0 0"
  184. :page-size="20"
  185. @current-change="newPage"
  186. :current-page="page"
  187. v-if="tableData.length > 0"
  188. background
  189. layout="prev, pager, next, jumper"
  190. :total="tableSum"
  191. >
  192. </el-pagination>
  193. </el-card>
  194. <!-- 填报弹框 -->
  195. <el-dialog
  196. title="填报"
  197. v-loading="loading1"
  198. :visible.sync="dialogVisible"
  199. width="800px"
  200. :close-on-click-modal="false"
  201. :close-on-press-escape="false"
  202. >
  203. <ul class="fill_ul">
  204. <li class="fill_listTlt">
  205. <div class="fill_div">
  206. <div class="fill_tltie">有害生物</div>
  207. <div class="fill_tltie">数量</div>
  208. </div>
  209. </li>
  210. <li class="fill_list1" v-if="fillList.length !== 0">
  211. <div v-for="(item, index) in fillList" :key="item.ind">
  212. <el-select
  213. v-model="models[index]"
  214. disabled
  215. size="mini"
  216. clearable
  217. @change="compileInsect($event, item, index)"
  218. placeholder="请选择"
  219. >
  220. <el-option
  221. v-for="item1 in fillList"
  222. :key="item1.value"
  223. :label="item1.label"
  224. :value="item1.value"
  225. >
  226. </el-option>
  227. </el-select>
  228. <el-input
  229. disabled
  230. placeholder="请输入内容"
  231. size="mini"
  232. v-model="item.num"
  233. clearable
  234. type="number"
  235. style="width: 30%"
  236. >
  237. </el-input>
  238. <span class="fill__appraisal" @click="handleAppraiseClick"
  239. >鉴定</span
  240. >
  241. <span @click="delInsect(item)">删除</span>
  242. </div>
  243. </li>
  244. <!-- 添加 -->
  245. <li class="fill_list">
  246. <el-select
  247. style="margin: 0 0 0 -8px"
  248. v-model="insectVal"
  249. size="mini"
  250. clearable
  251. placeholder="请选择"
  252. filterable
  253. >
  254. <el-option
  255. v-for="item1 in options2"
  256. :key="item1.value"
  257. :label="item1.label"
  258. :value="item1.value"
  259. :disabled="item1.disabled"
  260. >
  261. </el-option>
  262. </el-select>
  263. <el-input
  264. placeholder="请输入数量"
  265. size="mini"
  266. v-model="numVal"
  267. clearable
  268. onkeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)));"
  269. @keyup.native="proving2($event)"
  270. type="number"
  271. style="width: 30%"
  272. >
  273. </el-input>
  274. <span
  275. style="color: #000; font-size: 30px; cursor: pointer"
  276. @click="addInsect()"
  277. >+</span
  278. >
  279. <span>&nbsp;</span>
  280. </li>
  281. </ul>
  282. <span slot="footer" class="dialog-footer">
  283. <el-button @click="dialogVisible = false">取 消</el-button>
  284. <el-button :disabled="submitBtn" type="primary" @click="confirmAxios">{{
  285. submitBtn == true ? '发布中...' : '发布'
  286. }}</el-button>
  287. </span>
  288. </el-dialog>
  289. <!-- 鉴定弹框 -->
  290. <el-dialog
  291. title="鉴定"
  292. v-loading="appraiseLoading"
  293. :visible.sync="appraiseDialogVisible"
  294. width="800px"
  295. :close-on-click-modal="false"
  296. :close-on-press-escape="false"
  297. >
  298. <el-form
  299. :model="ruleForm"
  300. :rules="rules"
  301. ref="ruleForm"
  302. label-width="140px"
  303. >
  304. <el-form-item label-width="20px">
  305. <el-descriptions>
  306. <el-descriptions-item label="样本名称">虫子</el-descriptions-item>
  307. <el-descriptions-item label="数量">12</el-descriptions-item>
  308. </el-descriptions>
  309. </el-form-item>
  310. <!-- start -->
  311. <el-row :gutter="20">
  312. <el-col :span="12">
  313. <el-form-item label="样本编号:" prop="desc">
  314. <el-input v-model="ruleForm.desc"></el-input>
  315. </el-form-item>
  316. </el-col>
  317. <el-col :span="12">
  318. <el-form-item label="标识:" prop="region">
  319. <el-select v-model="ruleForm.region" placeholder="请选择">
  320. <el-option label="区域一" value="shanghai"></el-option>
  321. <el-option label="区域二" value="beijing"></el-option>
  322. </el-select>
  323. </el-form-item>
  324. </el-col>
  325. </el-row>
  326. <el-row :gutter="20">
  327. <el-col :span="12">
  328. <el-form-item label="雌:" prop="region">
  329. <el-input
  330. v-model="ruleForm.name"
  331. onkeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)));"
  332. ></el-input>
  333. </el-form-item>
  334. </el-col>
  335. <el-col :span="12">
  336. <el-form-item label="雄:" prop="name">
  337. <el-input
  338. v-model="ruleForm.name"
  339. onkeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)));"
  340. ></el-input>
  341. </el-form-item>
  342. </el-col>
  343. </el-row>
  344. <el-form-item label="监测项目与方法:" prop="desc">
  345. <el-input type="textarea" v-model="ruleForm.desc"></el-input>
  346. </el-form-item>
  347. <el-form-item label="形态学鉴定:" prop="desc">
  348. <el-input type="textarea" v-model="ruleForm.desc"></el-input>
  349. </el-form-item>
  350. <el-form-item label="鉴定结果:" prop="desc">
  351. <el-input type="textarea" v-model="ruleForm.desc"></el-input>
  352. </el-form-item>
  353. <el-form-item label="备注:" prop="desc">
  354. <el-input type="textarea" v-model="ruleForm.desc"></el-input>
  355. </el-form-item>
  356. <!-- end -->
  357. </el-form>
  358. <span slot="footer" class="dialog-footer">
  359. <el-button @click="appraiseDialogVisible = false">取 消</el-button>
  360. <el-button :disabled="appraiseSubmitLoading" type="primary"
  361. >确定</el-button
  362. >
  363. </span>
  364. </el-dialog>
  365. </div>
  366. </template>
  367. <script>
  368. export default {
  369. components: {},
  370. data() {
  371. //这里存放数据
  372. return {
  373. fullHeight: document.documentElement.clientHeight - 116, //
  374. // 筛选
  375. input: '', // 任务处理人
  376. conductorList: [], // 任务处理人列表
  377. options: [
  378. {
  379. value: '待接收',
  380. label: '待接收'
  381. },
  382. {
  383. value: '已接收',
  384. label: '已接收'
  385. },
  386. {
  387. value: '已填报',
  388. lanbel: '已填报'
  389. }
  390. ],
  391. value: '', // 任务状态
  392. value1: '', // 时间筛选
  393. startTime: '',
  394. endTime: '',
  395. // 表格
  396. tableData: [],
  397. page: 1,
  398. tableSum: 0, // 总页数
  399. // 填报弹框
  400. dialogVisible: false,
  401. options1: [],
  402. options2: [], //新增有害生物
  403. value2: '',
  404. input2: '',
  405. loading: false, // 加载
  406. // 已识别
  407. examineObj: {}, // 选中的对象值
  408. fillList: [], // 填报详情数据
  409. spareData: [], // 填报详情备用数据
  410. // models: Array(fillList.length).fill(''), // 填报select数据
  411. models: null, // 填报select数据
  412. insectVal: '', // 添加 - 有害生物
  413. numVal: '', // 添加 - 数量
  414. loading1: false, // 加载
  415. submitBtn: false, // 防止弹框确定按钮重复请求
  416. appraiseLoading: false,
  417. appraiseDialogVisible: false,
  418. appraiseSubmitLoading: false,
  419. ruleForm: {
  420. name: '',
  421. region: '',
  422. date1: '',
  423. date2: '',
  424. delivery: false,
  425. type: [],
  426. resource: '',
  427. desc: ''
  428. },
  429. rules: {
  430. name: [
  431. { required: true, message: '请输入活动名称', trigger: 'blur' },
  432. { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' }
  433. ],
  434. region: [
  435. { required: true, message: '请选择活动区域', trigger: 'change' }
  436. ],
  437. date1: [
  438. {
  439. type: 'date',
  440. required: true,
  441. message: '请选择日期',
  442. trigger: 'change'
  443. }
  444. ],
  445. date2: [
  446. {
  447. type: 'date',
  448. required: true,
  449. message: '请选择时间',
  450. trigger: 'change'
  451. }
  452. ],
  453. type: [
  454. {
  455. type: 'array',
  456. required: true,
  457. message: '请至少选择一个活动性质',
  458. trigger: 'change'
  459. }
  460. ],
  461. resource: [
  462. { required: true, message: '请选择活动资源', trigger: 'change' }
  463. ],
  464. desc: [{ required: true, message: '请填写活动形式', trigger: 'blur' }]
  465. }
  466. };
  467. },
  468. //监听属性 类似于data概念
  469. computed: {},
  470. //监控data中的数据变化
  471. watch: {
  472. fullHeight(val) {
  473. //监控浏览器高度变化
  474. if (!this.timer) {
  475. this.fullHeight = val;
  476. this.timer = true;
  477. let that = this;
  478. setTimeout(function() {
  479. //防止过度调用监测事件,导致卡顿
  480. that.timer = false;
  481. }, 400);
  482. }
  483. },
  484. // 填报弹框
  485. dialogVisible(val) {
  486. if (val == false) {
  487. this.fillList = [];
  488. this.models = [];
  489. this.spareData = []; // 备用数据
  490. }
  491. },
  492. // 填报 - 新添加数据
  493. numValZ(val) {
  494. console.log(val);
  495. }
  496. },
  497. //方法集合
  498. methods: {
  499. //动态获取浏览器高度
  500. get_boderHeight() {
  501. const that = this;
  502. window.onresize = () => {
  503. return (() => {
  504. window.fullHeight = document.documentElement.clientHeight;
  505. that.fullHeight = window.fullHeight;
  506. })();
  507. };
  508. },
  509. // 筛选
  510. searchData() {
  511. // 对时间筛选中获取到的时间进行处理
  512. if (this.value1) {
  513. this.startTime = this.formatTime(this.value1[0], 'yyyy-MM-dd');
  514. this.endTime = this.formatTime(this.value1[1], 'yyyy-MM-dd');
  515. } else {
  516. this.startTime = '';
  517. this.endTime = '';
  518. }
  519. this.loading = true;
  520. this.page = 1;
  521. this.tableData = [];
  522. this.tableList();
  523. },
  524. // 重置
  525. reset() {
  526. this.input = '';
  527. this.value = '';
  528. this.value1 = '';
  529. this.startTime = '';
  530. this.endTime = '';
  531. this.loading = true;
  532. this.page = 1;
  533. this.tableList();
  534. },
  535. // 下页
  536. newPage(page) {
  537. this.loading = true;
  538. this.page = page;
  539. this.tableData = [];
  540. this.tableList();
  541. },
  542. // 表格数据
  543. tableList() {
  544. this.$axios({
  545. method: 'POST',
  546. url: '/api/api_gateway?method=control_center.task.discern_list',
  547. data: this.qs.stringify({
  548. page: this.page,
  549. page_item: 20,
  550. operator_user_id: this.input, // 任务处理人id
  551. start_time: this.startTime, // 开始时间
  552. end_time: this.endTime, // 结束时间
  553. task_status: this.value // 任务状态
  554. })
  555. })
  556. .then(res => {
  557. if (res.data.data.total_item !== 0) {
  558. this.tableSum = res.data.data.total_item;
  559. var data = res.data.data.page_list;
  560. var list = [];
  561. data.forEach((item, index) => {
  562. item.serial = index + 1;
  563. list.push(item);
  564. });
  565. this.tableData = list;
  566. }
  567. this.loading = false;
  568. })
  569. .catch(err => {
  570. this.loading = false;
  571. });
  572. },
  573. // 筛选列表 - 任务处理人
  574. conductorAxios() {
  575. this.$axios({
  576. method: 'POST',
  577. url: '/api/api_gateway?method=control_center.task.task_user_list',
  578. data: this.qs.stringify({
  579. user_type: 'operator', // 用户类型,operator(任务处理人), supervisor(任务监督人), owner(任务发布人)
  580. operator_id: '', // 已经选择的任务处理人id
  581. supervisor_id: '', // 已经选择的任务监督人id
  582. owner_id: '' // 已经选择的任务发布人id
  583. })
  584. })
  585. .then(res => {
  586. if (res.data.data.length !== 0) {
  587. var data = res.data.data;
  588. var list = [];
  589. data.forEach(item => {
  590. var obj = {};
  591. obj['value'] = item.user_id;
  592. obj['label'] = item.real_name;
  593. list.push(obj);
  594. });
  595. this.conductorList = list;
  596. }
  597. })
  598. .catch(err => {});
  599. },
  600. // 确认接收
  601. receive(data) {
  602. this.$confirm('此操作将确认接收, 是否继续?', '提示', {
  603. confirmButtonText: '确定',
  604. cancelButtonText: '取消',
  605. type: 'warning'
  606. })
  607. .then(() => {
  608. this.$axios({
  609. method: 'POST',
  610. url: '/api/api_gateway?method=control_center.task.discern_modify',
  611. data: this.qs.stringify({
  612. record_id: data.id // 任务id
  613. })
  614. })
  615. .then(res => {
  616. if (res.data.data == true) {
  617. if (document.getElementsByClassName('el-message').length == 0) {
  618. this.$message({
  619. type: 'success',
  620. message: '接收成功!',
  621. duration: 1500
  622. });
  623. }
  624. this.loading = true;
  625. this.tableList();
  626. }
  627. })
  628. .catch(err => {
  629. console.log(err);
  630. });
  631. })
  632. .catch(() => {
  633. if (document.getElementsByClassName('el-message').length == 0) {
  634. this.$message({
  635. type: 'info',
  636. message: '已取消接收',
  637. duration: 1500
  638. });
  639. }
  640. });
  641. },
  642. // 填报、编辑事件 (表格中的操作)
  643. examine(data) {
  644. // console.log(data);
  645. this.examineObj = data;
  646. // 填报记录详情接口
  647. this.$axios({
  648. method: 'POST',
  649. url:
  650. '/api/api_gateway?method=control_center.task.trap_pest_record_info',
  651. data: this.qs.stringify({
  652. trap_record_id: data.id // 任务id
  653. })
  654. })
  655. .then(res => {
  656. var data = res.data.data;
  657. var list = [];
  658. var arr = [];
  659. data.forEach((item, index) => {
  660. var obj = {};
  661. obj['value'] = item.id;
  662. obj['label'] = item.pest_name;
  663. obj['num'] = item.pest_number;
  664. obj['ind'] = index;
  665. obj['disabled'] = false;
  666. list.push(obj);
  667. arr.push(item.id);
  668. });
  669. this.fillList = list;
  670. this.spareData = list; // 备用数据
  671. this.models = arr;
  672. this.dialogVisible = true;
  673. this.addEditor(); // 新添加 - 编辑接口
  674. })
  675. .catch(err => {
  676. console.log(err);
  677. });
  678. },
  679. // 新添加 -编辑
  680. addEditor() {
  681. this.$axios({
  682. method: 'POST',
  683. url: '/api/api_gateway?method=sysmenage.maintain.pest_list',
  684. data: this.qs.stringify({
  685. page: 1, // 页码
  686. page_item: '1000000000000000000000000000', // 每页条目数,默认10
  687. pest_name: '' // 有害生物
  688. })
  689. })
  690. .then(res => {
  691. if (res.data.data.total_item !== 0) {
  692. var data = res.data.data;
  693. var list = [];
  694. for (var i = 0; i < data.page_list.length; i++) {
  695. var obj = {};
  696. obj['id'] = data.page_list[i].pest_id;
  697. obj['value'] = data.page_list[i].pest_name;
  698. obj['label'] = data.page_list[i].pest_name;
  699. obj['disabled'] = false;
  700. list.push(obj);
  701. }
  702. this.options2 = list;
  703. this.indexRedact(); // 有害生物删除添加
  704. }
  705. })
  706. .catch(err => {
  707. console.log(err);
  708. });
  709. },
  710. // 添加有害生物
  711. addInsect() {
  712. if (this.insectVal !== '' && this.numVal !== '') {
  713. var array = [];
  714. var arr = [];
  715. for (var i = 0; i < this.options2.length; i++) {
  716. if (this.options2[i].label == this.insectVal) {
  717. var obj = {};
  718. obj['value'] = this.options2[i].id;
  719. obj['label'] = this.options2[i].label;
  720. obj['num'] = Number(this.numVal);
  721. arr = [obj, ...this.fillList];
  722. this.models = [obj.value, ...this.models];
  723. }
  724. }
  725. // 修改原数据
  726. this.fillList = [];
  727. this.insectVal = '';
  728. this.numVal = '';
  729. arr.forEach((item, index) => {
  730. item.ind = index;
  731. this.fillList.push(item);
  732. });
  733. // for (var i = 0; i < this.fillList.length; i++) {
  734. // for (var j = 0; j < this.options2.length; j++) {
  735. // if (this.fillList[i].label == this.options2[j].label) {
  736. // this.options2[j].disabled = true;
  737. // } else {
  738. // this.options2[j].disabled = false;
  739. // }
  740. // }
  741. // }
  742. this.indexRedact(); // 有害生物添加
  743. } else {
  744. if (document.getElementsByClassName('el-message').length == 0) {
  745. this.$message({
  746. type: 'info',
  747. message: '请将信息填写完整!',
  748. duration: 1500
  749. });
  750. }
  751. }
  752. },
  753. // 删除有害生物
  754. delInsect(data) {
  755. this.$delete(this.fillList, data.ind); // 删除渲染列表对应数据
  756. this.$delete(this.models, data.ind); // 删除对应双向绑定数据
  757. var list = [];
  758. this.fillList.forEach((item, index) => {
  759. item.ind = index;
  760. list.push(item);
  761. });
  762. this.fillList = [];
  763. this.fillList = list;
  764. this.options2.forEach(item => {
  765. item.disabled = false;
  766. });
  767. this.indexRedactA(); // 有害生物删除
  768. },
  769. // 添加、删除确定事件
  770. confirmAxios() {
  771. this.submitBtn = true;
  772. var array = [];
  773. for (var i = 0; i < this.fillList.length; i++) {
  774. var obj = {};
  775. obj['pest_name'] = this.fillList[i].label;
  776. obj['pest_number'] = this.fillList[i].num;
  777. array.push(obj);
  778. }
  779. if (this.insectVal !== '' && this.numVal !== '') {
  780. array = [
  781. {
  782. pest_name: this.insectVal,
  783. pest_number: this.numVal
  784. },
  785. ...array
  786. ];
  787. }
  788. this.$axios({
  789. method: 'POST',
  790. url: '/api/api_gateway?method=control_center.task.discern_add',
  791. data: this.qs.stringify({
  792. record_id: this.examineObj.id, // 任务id
  793. pest_list: JSON.stringify(array) // 害虫数组
  794. })
  795. })
  796. .then(res => {
  797. if (res.data.message == '') {
  798. if (document.getElementsByClassName('el-message').length == 0) {
  799. this.$message({
  800. type: 'success',
  801. message: '成功!',
  802. duration: 1500
  803. });
  804. }
  805. this.fillList = [];
  806. this.models = [];
  807. this.dialogVisible = false;
  808. }
  809. this.insectVal = '';
  810. this.numVal = '';
  811. this.submitBtn = false;
  812. })
  813. .catch(err => {
  814. this.submitBtn = false;
  815. });
  816. },
  817. // 编辑有害生物
  818. compileInsect(e, data, index) {
  819. var list = this.spareData;
  820. var newList = [];
  821. // 下拉框数据改变处理
  822. var name = '';
  823. for (var i = 0; i < list.length; i++) {
  824. var obj = {};
  825. if (e == list[i].value) {
  826. name = list[i].label;
  827. }
  828. }
  829. this.$set(this.models, index, e);
  830. this.fillList[index].label = name;
  831. this.fillList[index].value = e;
  832. },
  833. getBit(value, bit) {
  834. let str = Number(value);
  835. str = str.toFixed(bit);
  836. return str;
  837. },
  838. proving2(e) {
  839. var keynum = window.event ? e.keyCode : e.which; //获取键盘码
  840. var keychar = String.fromCharCode(keynum); //获取键盘码对应的字符
  841. if (keynum == 189 || keynum == 109) {
  842. //禁止输入负数
  843. if (document.getElementsByClassName('el-message').length == 0) {
  844. this.$message.warning('禁止输入负数');
  845. }
  846. e.target.value = 0;
  847. }
  848. if (String(e.target.value).indexOf('-') == -1) {
  849. } else {
  850. //禁止输入负数
  851. if (document.getElementsByClassName('el-message').length == 0) {
  852. this.$message.warning('禁止输入负数');
  853. }
  854. e.target.value = 0;
  855. }
  856. },
  857. // 有害生物添加
  858. indexRedact() {
  859. this.fillList.forEach(item => {
  860. this.options2.forEach(e => {
  861. if (item.label == e.label) {
  862. e.disabled = true;
  863. // console.log(e.label, e.disabled);
  864. }
  865. });
  866. });
  867. },
  868. // 有害生物删除
  869. indexRedactA() {
  870. this.fillList.forEach(item => {
  871. this.options2.forEach(e => {
  872. if (item.label == e.label) {
  873. // console.log(e.label, e.disabled)
  874. e.disabled = true;
  875. }
  876. });
  877. });
  878. },
  879. handleAppraiseClick() {
  880. this.appraiseDialogVisible = true;
  881. },
  882. submitForm(formName) {
  883. this.$refs[formName].validate(valid => {
  884. if (valid) {
  885. alert('submit!');
  886. } else {
  887. console.log('error submit!!');
  888. return false;
  889. }
  890. });
  891. },
  892. resetForm(formName) {
  893. this.$refs[formName].resetFields();
  894. }
  895. },
  896. //生命周期 - 创建完成(可以访问当前this实例)
  897. created() {},
  898. //生命周期 - 挂载完成(可以访问DOM元素)
  899. mounted() {
  900. this.loading = true;
  901. this.get_boderHeight(); // 动态获取浏览器高度
  902. this.tableList(); // 表格列表数据
  903. this.conductorAxios(); // 筛选列表 - 任务处理人列表
  904. },
  905. beforeCreate() {}, //生命周期 - 创建之前
  906. beforeMount() {}, //生命周期 - 挂载之前
  907. beforeUpdate() {}, //生命周期 - 更新之前
  908. updated() {}, //生命周期 - 更新之后
  909. beforeDestroy() {}, //生命周期 - 销毁之前
  910. destroyed() {}, //生命周期 - 销毁完成
  911. activated() {} //如果页面有keep-alive缓存功能,这个函数会触发
  912. };
  913. </script>
  914. <style lang="less" scoped>
  915. .laboratory_box {
  916. // 搜索
  917. .search_box {
  918. display: flex;
  919. /deep/.el-select {
  920. margin: 0 15px 0 0;
  921. }
  922. /deep/.el-input {
  923. // width: 15%;
  924. margin: 0 15px 0 0;
  925. }
  926. .btn_box {
  927. margin: 0 0 0 15px;
  928. // width: 50%;
  929. display: flex;
  930. justify-content: start;
  931. }
  932. /deep/.el-range-editor--mini.el-input__inner {
  933. width: 20%;
  934. }
  935. }
  936. a {
  937. text-decoration: none;
  938. }
  939. .reset {
  940. color: #1890ff;
  941. }
  942. // 填报弹框
  943. .fill_ul {
  944. .fill_listTlt {
  945. width: 95%;
  946. .fill_div {
  947. width: 60%;
  948. margin: 0 0 0 60px;
  949. display: flex;
  950. justify-content: space-between;
  951. .fill_tltie {
  952. margin: 0 0 10px 0;
  953. width: 35%;
  954. display: inline-block;
  955. }
  956. }
  957. }
  958. .fill_list {
  959. display: flex;
  960. justify-content: space-around;
  961. margin: 0 20px 10px 0;
  962. span {
  963. line-height: 30px;
  964. color: #1890ff;
  965. }
  966. }
  967. .fill_list1 {
  968. div {
  969. display: flex;
  970. justify-content: space-around;
  971. margin: 0 20px 10px 0;
  972. span {
  973. line-height: 30px;
  974. color: #1890ff;
  975. cursor: pointer;
  976. &.fill__appraisal {
  977. color: #f55106;
  978. text-decoration: underline;
  979. }
  980. }
  981. }
  982. }
  983. }
  984. /deep/.el-card {
  985. overflow: hidden;
  986. overflow-y: auto;
  987. }
  988. }
  989. // 去除elementui input数字框里上下箭头
  990. /deep/ input::-webkit-outer-spin-button,
  991. /deep/ input::-webkit-inner-spin-button {
  992. -webkit-appearance: none !important;
  993. }
  994. /deep/ input[type='number'] {
  995. -moz-appearance: textfield !important;
  996. }
  997. /deep/.el-date-editor {
  998. cursor: pointer;
  999. .el-range-input {
  1000. cursor: pointer;
  1001. }
  1002. }
  1003. /deep/.el-button--info {
  1004. background-color: #409eff;
  1005. border-color: #409eff;
  1006. }
  1007. .fill {
  1008. &__appraisal {
  1009. color: rgba(245, 81, 6, 1);
  1010. }
  1011. }
  1012. </style>