baseInfo.vue 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839
  1. <template>
  2. <el-form ref="form1" :model="form" :rules="rules" label-width="120px">
  3. <el-row>
  4. <el-col :span="6">
  5. <el-form-item label="编码:">
  6. <el-input
  7. :maxlength="20"
  8. v-model="form.code"
  9. disabled
  10. placeholder="请输入"
  11. />
  12. </el-form-item>
  13. </el-col>
  14. <!-- <el-col :span="6">
  15. <el-form-item label="质检类型:" prop="qualityType">
  16. <DictSelection
  17. dictName="质检计划类型"
  18. v-model="form.qualityType"
  19. :disabled="btnType == 'detail'"
  20. ></DictSelection>
  21. </el-form-item>
  22. </el-col>
  23. <el-col :span="6">
  24. <el-form-item label="质检方式:" prop="qualityMode">
  25. <DictSelection
  26. dictName="取样类型"
  27. v-model="form.qualityMode"
  28. clearable
  29. :disabled="btnType == 'detail'"
  30. ></DictSelection>
  31. </el-form-item>
  32. </el-col>-->
  33. <el-col :span="6">
  34. <el-form-item label="产品名称:" prop="productName">
  35. <el-input
  36. disabled
  37. v-model="form.productName"
  38. @click.native="addProduct"
  39. readonly
  40. placeholder="请选择"
  41. />
  42. </el-form-item>
  43. </el-col>
  44. <el-col :span="6">
  45. <el-form-item label="产品编码:" prop="productCode">
  46. <el-input v-model="form.productCode" disabled />
  47. </el-form-item>
  48. </el-col>
  49. <el-col :span="6">
  50. <el-form-item label="批次号:" prop="batchNo">
  51. <el-input v-model="form.batchNo" disabled />
  52. </el-form-item>
  53. </el-col>
  54. </el-row>
  55. <el-row>
  56. <el-col :span="6">
  57. <el-form-item label="规格:" prop="specification">
  58. <el-input v-model="form.specification" disabled />
  59. </el-form-item>
  60. </el-col>
  61. <el-col :span="6">
  62. <el-form-item label="型号:" prop="modelType">
  63. <el-input v-model="form.modelType" disabled />
  64. </el-form-item>
  65. </el-col>
  66. <el-col :span="6">
  67. <el-form-item label="牌号:" prop="brandNo">
  68. <el-input v-model="form.brandNo" disabled />
  69. </el-form-item>
  70. </el-col>
  71. <el-col :span="6">
  72. <el-form-item label="计量类型" prop="inspectionStandards">
  73. <!-- 计量 计重 -->
  74. <el-select
  75. style="width: 100%"
  76. v-model="form.inspectionStandards"
  77. placeholder="请选择"
  78. :disabled="true"
  79. >
  80. <el-option
  81. v-for="item in inspectionStandardsList"
  82. :label="item.label"
  83. :value="item.value"
  84. :key="item.value"
  85. ></el-option>
  86. </el-select>
  87. </el-form-item>
  88. </el-col>
  89. <!-- <el-col :span="6">
  90. <el-form-item label="总数量:" prop="total">
  91. <el-input
  92. type="number"
  93. v-model="form.total"
  94. @input="inputTotal"
  95. disabled
  96. />
  97. </el-form-item>
  98. </el-col> -->
  99. </el-row>
  100. <!-- <div style="text-align: right; margin-bottom: 22px">
  101. <div @click="toggleExpand">
  102. <div v-if="isExpanded"> <i class="el-icon-arrow-up"></i>收起 </div>
  103. <div v-if="!isExpanded">
  104. <i class="el-icon-arrow-down"></i>展开更多
  105. </div>
  106. </div>
  107. </div> -->
  108. <!-- v-if="isExpanded" -->
  109. <div>
  110. <el-row>
  111. <el-col :span="6">
  112. <el-form-item
  113. label="执行部门"
  114. prop="executeDeptId"
  115. v-if="form.qualityType != 2"
  116. >
  117. <deptSelect
  118. :disabled="btnType == 'detail'"
  119. v-model="form.executeDeptId"
  120. @changeGroup="searchDeptNodeClick"
  121. />
  122. </el-form-item>
  123. </el-col>
  124. <el-col :span="6" v-if="form.qualityType == 2">
  125. <el-form-item label="执行班组" prop="executeJobId">
  126. <el-select
  127. :disabled="btnType == 'detail'"
  128. v-model="form.executeJobId"
  129. size="small"
  130. style="width: 100%"
  131. >
  132. <el-option
  133. v-for="item in form.jobList"
  134. :key="item.id"
  135. :value="item.id"
  136. :label="item.name"
  137. @click.native="changeExecuteJob(item)"
  138. ></el-option>
  139. </el-select>
  140. </el-form-item>
  141. </el-col>
  142. <el-col :span="6">
  143. <el-form-item label="执行人" prop="executeUserId">
  144. <el-select
  145. :disabled="btnType == 'detail'"
  146. v-model="form.executeUserIdList"
  147. size="small"
  148. style="width: 100%"
  149. filterable
  150. multiple
  151. @change="executeUserIdChange"
  152. >
  153. <el-option
  154. v-for="item in form.qualityType == 2
  155. ? form.jobList.find((job) => job.id == form.executeJobId)
  156. ?.userVOList
  157. : executorList"
  158. :key="item.id"
  159. :value="item.id"
  160. :label="item.name"
  161. ></el-option>
  162. </el-select>
  163. </el-form-item>
  164. </el-col>
  165. <el-col :span="6">
  166. <el-form-item label="质检时间:" prop="qualityTime">
  167. <el-date-picker
  168. v-model="form.qualityTime"
  169. class="w100"
  170. type="datetime"
  171. value-format="yyyy-MM-dd HH:mm:ss"
  172. :disabled="btnType == 'detail'"
  173. placeholder="选择日期"
  174. >
  175. </el-date-picker>
  176. </el-form-item>
  177. </el-col>
  178. <el-col :span="6">
  179. <el-form-item label="工时(h):" prop="hours">
  180. <el-input
  181. v-model="form.hours"
  182. :disabled="btnType == 'detail'"
  183. ></el-input>
  184. </el-form-item>
  185. </el-col>
  186. </el-row>
  187. <el-row>
  188. <el-col :span="6">
  189. <el-form-item label="接收人部门" prop="groupId">
  190. <!-- <deptSelect
  191. :disabled="btnType == 'detail' || form.qualityType == 2"
  192. v-model="form.groupId"
  193. @changeGroup="searchDeptNodeClick"
  194. /> -->
  195. <el-input v-model="form.groupName" disabled></el-input>
  196. </el-form-item>
  197. </el-col>
  198. <el-col :span="6">
  199. <el-form-item label="接收人" prop="qualityIdList">
  200. <el-input v-model="form.qualityName" disabled></el-input>
  201. <!-- <el-select
  202. :disabled="btnType == 'detail' || form.qualityType == 2"
  203. v-model="form.qualityIdList"
  204. @change="changeExecutor"
  205. size="small"
  206. style="width: 100%"
  207. filterable
  208. multiple
  209. >
  210. <el-option
  211. v-for="item in executorList"
  212. :key="item.id"
  213. :value="item.id"
  214. :label="item.name"
  215. ></el-option>
  216. </el-select> -->
  217. </el-form-item>
  218. </el-col>
  219. </el-row>
  220. <el-row>
  221. <el-col :span="6">
  222. <el-form-item
  223. label="合格数:"
  224. prop="qualifiedNumber"
  225. v-if="showArrange == '1'"
  226. >
  227. <el-input
  228. :min="0"
  229. @input="limitation('qualifiedNumber', form.qualifiedNumber)"
  230. @blur="quantityCalculation('qualifiedNumber')"
  231. v-model="form.qualifiedNumber"
  232. placeholder="请输入"
  233. ></el-input>
  234. </el-form-item>
  235. </el-col>
  236. <el-col :span="6">
  237. <el-form-item
  238. label="不合格数:"
  239. prop="noQualifiedNumber"
  240. v-if="showArrange == '1'"
  241. >
  242. <el-input
  243. :min="0"
  244. @input="limitation('noQualifiedNumber', form.noQualifiedNumber)"
  245. @blur="quantityCalculation('noQualifiedNumber')"
  246. v-model="form.noQualifiedNumber"
  247. placeholder="请输入"
  248. ></el-input>
  249. </el-form-item>
  250. </el-col>
  251. <el-col :span="6">
  252. <el-form-item label="合格率:" prop="qualificationRate">
  253. <el-input v-model="form.qualificationRate" disabled />
  254. </el-form-item>
  255. </el-col>
  256. <el-col :span="6">
  257. <el-form-item label="不合格率:" prop="noQualificationRate">
  258. <el-input v-model="form.noQualificationRate" disabled />
  259. </el-form-item>
  260. </el-col>
  261. <el-col :span="6">
  262. <el-form-item label="检验方式:" prop="qualityMode">
  263. <!-- <DictSelection dictName="取样类型" v-model="form.qualityMode" :disabled="qualityType == 1"></DictSelection> -->
  264. <el-select
  265. @change="changeQualityMode"
  266. style="width: 100%"
  267. v-model="form.qualityMode"
  268. placeholder="请选择"
  269. >
  270. <!-- :disabled="
  271. parseInt(qualityType1) == 1 || parseInt(qualityType1) == 3
  272. " -->
  273. <el-option
  274. v-for="item in qualityModeList"
  275. :label="item.label"
  276. :value="item.value"
  277. :key="item.value"
  278. ></el-option>
  279. </el-select>
  280. </el-form-item>
  281. </el-col>
  282. <el-col :span="6">
  283. <!-- <el-form-item label="质检结果:" prop="qualityResults" v-if="form.qualityMode == 2"> -->
  284. <el-form-item label="质检结果:" prop="qualityResults">
  285. <!-- :disabled="btnType == 'detail'" -->
  286. <el-select
  287. v-model="form.qualityResults"
  288. placeholder="请选择"
  289. style="width: 100%"
  290. :disabled="showArrange == '0'"
  291. @change="selectResult"
  292. >
  293. <el-option label="合格" :value="1" />
  294. <el-option label="不合格" :value="2" />
  295. </el-select>
  296. </el-form-item>
  297. </el-col>
  298. <el-col :span="6">
  299. <el-form-item label="总重量:" prop="totalWeight">
  300. <el-input
  301. type="number"
  302. :disabled="btnType == 'detail'"
  303. v-model="form.totalWeight"
  304. />
  305. </el-form-item>
  306. </el-col>
  307. <el-col :span="6">
  308. <el-form-item label="总数量:" prop="total">
  309. <el-input
  310. type="number"
  311. v-model="form.total"
  312. @input="inputTotal"
  313. disabled
  314. />
  315. </el-form-item>
  316. </el-col>
  317. <el-col :span="showArrange == '1' ? 24 : 12">
  318. <el-form-item label="备注:" prop="remark">
  319. <el-input
  320. type="textarea"
  321. v-model="form.remark"
  322. placeholder="请输入"
  323. :disabled="btnType == 'detail'"
  324. />
  325. </el-form-item>
  326. </el-col>
  327. <!-- <el-col :span="6" v-if="btnType != 'detail'">
  328. <el-form-item label="取样数量:" prop="sampleNumber" :rules="{
  329. required: form.qualityMode == 2 ? true : false,
  330. message: '请输入取样数量',
  331. trigger: 'blur'
  332. }" v-if="form.qualityMode == 2">
  333. <div style="display: flex;align-items: center;justify-content: space-between;">
  334. <el-input type="number"
  335. :disabled="form.qualityMode == null || form.qualityMode == 1 || (form.qualityMode == 2 && form.sampleNumber) ? true : false"
  336. v-model="form.sampleNumber" @change="handleChangeNumber" style="width: calc(100% - 90px)" />
  337. <DictSelection dictName="计量单位" clearable v-model="form.sampleMeasureUnit" disabled size="mini"
  338. style="width: 90px;margin-left: 12px;">
  339. </DictSelection>
  340. </div>
  341. </el-form-item>
  342. </el-col>-->
  343. <!-- <el-col :span="6" v-if="btnType != 'detail'">
  344. <el-form-item label="取样数量:" prop="sampleNumber" :rules="{
  345. required: form.qualityMode == 2 ? true : false,
  346. message: '请输入取样数量',
  347. trigger: 'blur'
  348. }" v-if="form.qualityMode == 2">
  349. <div style="display: flex;align-items: center;justify-content: space-between;">
  350. <el-input type="number"
  351. :disabled="form.qualityMode == null || form.qualityMode == 1 || (form.qualityMode == 2 && form.sampleNumber) ? true : false"
  352. v-model="form.sampleNumber" @change="handleChangeNumber" style="width: calc(100% - 90px)" />
  353. <DictSelection dictName="计量单位" clearable v-model="form.sampleMeasureUnit" disabled size="mini"
  354. style="width: 90px;margin-left: 12px;">
  355. </DictSelection>
  356. </div>
  357. </el-form-item>
  358. </el-col>-->
  359. <!-- <el-col :span="6">
  360. <el-form-item label="合格证号:" prop="certificateNumber">
  361. <el-input
  362. v-model="form.certificateNumber"
  363. :disabled="btnType == 'detail'"
  364. placeholder="请输入"
  365. ></el-input>
  366. </el-form-item>
  367. </el-col> -->
  368. <el-col :span="6" v-if="parseInt(qualityType1) == 2">
  369. <el-form-item label="工艺路线:">
  370. <el-input
  371. @click.native="openVersion"
  372. clearable
  373. v-model="form.produceRoutingName"
  374. :disabled="btnType == 'detail'"
  375. placeholder="请选择"
  376. />
  377. </el-form-item>
  378. </el-col>
  379. <el-col :span="6" v-if="parseInt(qualityType1) == 2">
  380. <el-form-item label="工序:">
  381. <el-select
  382. style="width: 100%"
  383. v-model="form.produceTaskId"
  384. placeholder="请选择"
  385. clearable
  386. @change="produceTaskChange"
  387. :disabled="btnType == 'detail'"
  388. >
  389. <el-option
  390. v-for="item in produceTaskList"
  391. :key="item.id"
  392. :label="item.name"
  393. :value="item.id"
  394. ></el-option>
  395. </el-select>
  396. </el-form-item>
  397. </el-col>
  398. <!-- <el-col :span="6">
  399. <el-form-item label="质检类型:">
  400. <el-input
  401. v-model="form.certificateNumber"
  402. disabled
  403. placeholder="请输入"
  404. ></el-input>
  405. </el-form-item>
  406. </el-col> -->
  407. <!-- 总数量 减去 样品数量 *** -->
  408. <!-- -->
  409. <!-- <el-col :span="6">
  410. <el-form-item label="质检结果数量:" prop="resultsTotal">
  411. <el-input
  412. type="number"
  413. v-model="form.resultsTotal"
  414. @input="inputTotal"
  415. disabled
  416. />
  417. </el-form-item>
  418. </el-col> -->
  419. <el-col :span="8">
  420. <el-form-item label="附件:" prop="accessory">
  421. <fileUpload
  422. v-model="form.accessory"
  423. :type="btnType == 'detail' ? 'view' : ''"
  424. />
  425. </el-form-item>
  426. </el-col>
  427. </el-row>
  428. </div>
  429. <ProductionVersion ref="versionRefs" @changeProduct="changeProduct" />
  430. <EquipmentDialog ref="equipmentRefs" @choose="choose" />
  431. </el-form>
  432. </template>
  433. <script>
  434. import deptSelect from '@/components/CommomSelect/dept-select.vue';
  435. import fileUpload from '@/components/addDoc/index.vue';
  436. import ProductionVersion from './ProductionVersion.vue';
  437. import EquipmentDialog from './EquipmentDialog.vue';
  438. //接口
  439. import { getUserPage } from '@/api/system/organization';
  440. import { getProduceTaskList } from '@/api/aps';
  441. import { getByCode } from '@/api/system/dictionary-data';
  442. import { parameterGetByCode } from '@/api/main/index';
  443. export default {
  444. components: {
  445. EquipmentDialog,
  446. ProductionVersion,
  447. deptSelect,
  448. fileUpload
  449. },
  450. props: {
  451. form: {
  452. type: Object,
  453. default: () => {}
  454. },
  455. btnType: {
  456. type: String,
  457. default: ''
  458. },
  459. qualityType1: {
  460. type: String,
  461. default: ''
  462. },
  463. sampleList: {
  464. type: Array,
  465. default: () => []
  466. }
  467. },
  468. watch: {
  469. // 'form.qualityMode': {
  470. // handler(newVal) {
  471. // if (newVal) {
  472. // this.$emit('changeModel', newVal);
  473. // } else {
  474. // console.log('清空样品清单');
  475. // // this.$emit('table2');
  476. // }
  477. // },
  478. // immediate: false
  479. // },
  480. // 'form.inspectionStandards': {
  481. // handler(newVal) {
  482. // if (newVal && this.qualityType1 == 2) {
  483. // this.$emit('changeInspectionStandardsModel', newVal);
  484. // } else {
  485. // console.log('清空样品清单');
  486. // // this.$emit('table2');
  487. // }
  488. // },
  489. // immediate: false
  490. // },
  491. // 新增 *** 监听合格率更改 质检结果
  492. // 'form.qualificationRate': {
  493. // handler(newVal) {
  494. // if (newVal == '100.00%' || newVal == '100%' || newVal == '100.0%') {
  495. // this.$set(this.form, 'qualityResults', 1);
  496. // } else {
  497. // this.$set(this.form, 'qualityResults', 2);
  498. // // this.$emit('table2');
  499. // }
  500. // },
  501. // immediate: false,
  502. // deep: true
  503. // }
  504. },
  505. data() {
  506. return {
  507. executorList: [],
  508. sourceList: [],
  509. rules: {
  510. productName: [
  511. { required: true, message: '请选择产品', trigger: 'change' }
  512. ],
  513. // qualifiedNumber: [
  514. // { required: true, message: '请输入合格数', trigger: 'blur' }
  515. // ],
  516. // noQualifiedNumber: [
  517. // { required: true, message: '请输入不合格数', trigger: 'blur' }
  518. // ],
  519. qualityTime: [
  520. { required: true, message: '请选择质检时间', trigger: 'blur' }
  521. ],
  522. groupId: [
  523. { required: true, message: '请选择质检部门', trigger: 'change' }
  524. ],
  525. executeJobId: [
  526. { required: true, message: '请选择执行班组', trigger: 'change' }
  527. ],
  528. executeDeptId: [
  529. { required: true, message: '请选择执行部门', trigger: 'change' }
  530. ],
  531. // qualityId: [
  532. // { required: true, message: '请选择质检人', trigger: 'change' }
  533. // ],
  534. // qualityIdList: [
  535. // { required: true, message: '请选择质检人', trigger: 'blur' }
  536. // ],
  537. qualityResults: [
  538. { required: true, message: '请选择质检结果', trigger: 'change' }
  539. ],
  540. inspectionStandards: [
  541. { required: true, message: '请选择检验标准', trigger: 'change' }
  542. ]
  543. },
  544. produceTaskList: [],
  545. inspectionStandardsList: [],
  546. qualityModeList: [],
  547. executeUserList: [],
  548. isExpanded: false,
  549. showArrange: '1'
  550. };
  551. },
  552. created() {
  553. this.getDictListIqoCode('measurement_type');
  554. this.getQualityModeList('quality_method_code');
  555. // 是否展示合格不合格
  556. this.getCode();
  557. },
  558. methods: {
  559. changeExecuteJob(item) {
  560. this.$set(this.form, 'executeJobName', item.name);
  561. this.$set(this.form, 'executeUserId', '');
  562. },
  563. getCode() {
  564. parameterGetByCode({
  565. code: 'qms_show_arrange'
  566. }).then((res) => {
  567. if (res) {
  568. this.showArrange = res.value || '1';
  569. // this.time_calc_code = res.value || '0';
  570. }
  571. });
  572. },
  573. // *** 只能输入大于0的数字
  574. limitation(val, num) {
  575. let newVal = num.replace(/[^\d.]/g, '');
  576. if (newVal.startsWith('.')) {
  577. newVal = '';
  578. }
  579. const firstDotIndex = newVal.indexOf('.');
  580. if (firstDotIndex !== -1) {
  581. newVal =
  582. newVal.slice(0, firstDotIndex + 1) +
  583. newVal.slice(firstDotIndex + 1).replace(/\./g, '');
  584. }
  585. const match = newVal.match(/^(\d+)(\.\d{0,9})?/);
  586. if (val == 'qualifiedNumber') {
  587. this.form.qualifiedNumber = match ? match[0] : '';
  588. }
  589. if (val == 'noQualifiedNumber') {
  590. this.form.noQualifiedNumber = match ? match[0] : '';
  591. }
  592. // this.form[val] =
  593. // this.form[val].replace(/[^\d]/g, '').replace(/^0+/, '') || '0';
  594. },
  595. // *** 计算合格数 不合格数
  596. quantityCalculation(e, noSetSampleList) {
  597. console.log(this.form, '执行没有');
  598. // return
  599. let qualifiedNumber = this.form.qualifiedNumber - 0;
  600. let noQualifiedNumber = this.form.noQualifiedNumber - 0;
  601. let total = this.form.total - 0;
  602. let val =
  603. e == 'qualifiedNumber' ? 'noQualifiedNumber' : 'qualifiedNumber';
  604. if (this.form[e] > this.form.total) {
  605. this.form[e] = this.form.total - this.form[val];
  606. this.$message.warning('合格数与不合格数不能大于总数量');
  607. return;
  608. }
  609. this.form[val] = this.form.total - this.form[e];
  610. if (e == 'qualifiedNumber') {
  611. noQualifiedNumber = total - this.form.qualifiedNumber;
  612. }
  613. if (e == 'noQualifiedNumber') {
  614. qualifiedNumber = total - this.form.noQualifiedNumber;
  615. }
  616. let passRate = ((qualifiedNumber / total) * 100).toFixed(2);
  617. let failureRate = ((noQualifiedNumber / total) * 100).toFixed(2);
  618. this.form.qualificationRate = passRate + '%';
  619. this.form.noQualificationRate = failureRate + '%';
  620. if (
  621. this.form.qualityMode == 1 &&
  622. this.form.isUnpack == 2 &&
  623. !noSetSampleList
  624. ) {
  625. this.$emit('quantityCalculation', qualifiedNumber);
  626. }
  627. return true;
  628. },
  629. deepCopy(obj, hash = new WeakMap()) {
  630. if (obj === null) return null;
  631. if (obj instanceof Date) return new Date(obj);
  632. if (obj instanceof RegExp) return new RegExp(obj);
  633. if (typeof obj !== 'object' && typeof obj !== 'function') return obj;
  634. if (hash.has(obj)) return hash.get(obj); // 处理循环引用
  635. const result = Array.isArray(obj) ? [] : {};
  636. hash.set(obj, result); // 存储原始对象和其副本的映射关系
  637. return Object.keys(obj).reduce((acc, key) => {
  638. acc[key] = this.deepCopy(obj[key], hash);
  639. return acc;
  640. }, result);
  641. },
  642. toggleExpand() {
  643. this.isExpanded = !this.isExpanded;
  644. },
  645. toggleExpand2() {
  646. this.isExpanded = true;
  647. this.$nextTick(() => {
  648. this.$refs.form1.validateField('qualityResults');
  649. });
  650. },
  651. async getDictListIqoCode(code) {
  652. let { data: res } = await getByCode(code);
  653. this.inspectionStandardsList = res.map((item) => {
  654. let values = Object.keys(item);
  655. return {
  656. value: Number(values[0]),
  657. label: item[values[0]]
  658. };
  659. });
  660. },
  661. async getQualityModeList(code) {
  662. let { data: res } = await getByCode(code);
  663. this.qualityModeList = res.map((item) => {
  664. let values = Object.keys(item);
  665. return {
  666. value: Number(values[0]),
  667. label: item[values[0]]
  668. };
  669. });
  670. },
  671. // 打开工艺路线弹窗
  672. openVersion() {
  673. this.$refs.versionRefs.open();
  674. },
  675. //工艺路线回调
  676. changeProduct(data) {
  677. this.form.produceRoutingId = data.id;
  678. this.form.produceRoutingName = data.name;
  679. this.form.produceTaskId = '';
  680. this.form.produceTaskName = '';
  681. this.getTaskList();
  682. },
  683. // 获取工序数据
  684. async getTaskList() {
  685. if (!this.form.produceRoutingId) {
  686. return;
  687. }
  688. const res = await getProduceTaskList({
  689. isDetail: true,
  690. pageNum: 1,
  691. routingId: this.form.produceRoutingId,
  692. size: -1
  693. });
  694. this.produceTaskList = res?.list;
  695. },
  696. // 选择工序
  697. produceTaskChange() {
  698. if (!this.form.produceTaskId) {
  699. return;
  700. }
  701. this.form.produceTaskName = this.produceTaskList.find(
  702. (item) => item.id == this.form.produceTaskId
  703. ).name;
  704. },
  705. // 产品名称
  706. addProduct() {
  707. this.$refs.equipmentRefs.open();
  708. },
  709. choose(data) {
  710. this.form.productCode = data[0].code;
  711. this.form.productName = data[0].name;
  712. this.form.specification = data[0].specification;
  713. this.form.modelType = data[0].modelType;
  714. this.form.brandNo = data[0].brandNum;
  715. },
  716. //选择部门(搜索)
  717. searchDeptNodeClick(info, row) {
  718. this.form.executeUserId = '';
  719. this.$set(this.form, 'executeUserName',' item.name');
  720. this.$set(this.form, 'executeUserIdList', '');
  721. if (info) {
  722. const params = { groupId: info };
  723. this.getUserList(params);
  724. this.form.executeDeptName = row.name;
  725. } else {
  726. this.form.executeDeptId = null;
  727. this.form.executeDeptName = null;
  728. }
  729. },
  730. // 获取人员
  731. async getUserList(params) {
  732. try {
  733. let data = { pageNum: 1, size: -1 };
  734. // 如果传了参数就是获取巡点检人员数据
  735. if (params) {
  736. data = Object.assign(data, params);
  737. }
  738. const res = await getUserPage(data);
  739. this.executorList = res.list;
  740. } catch (error) {}
  741. },
  742. // 人员选择
  743. changeExecutor(val) {
  744. this.$set(this.form, 'qualityIdList', val);
  745. if (val.length) {
  746. this.form.qualityName = val
  747. .map(
  748. (item) =>
  749. this.executorList.find((item2) => item2.id == item)?.name
  750. )
  751. .join(',');
  752. } else {
  753. this.form.qualityName = '';
  754. }
  755. this.$forceUpdate();
  756. },
  757. // 人员选择
  758. executeUserIdChange(val) {
  759. if (val.length) {
  760. let arr =
  761. this.form.qualityType == 2
  762. ? this.form.jobList.find(
  763. (job) => job.id == this.form.executeJobId
  764. )?.userVOList
  765. : this.executorList;
  766. this.form.executeUserName = val
  767. .map((item) => arr.find((item2) => item2.id == item)?.name)
  768. .join(',');
  769. } else {
  770. this.form.executeUserName = '';
  771. }
  772. this.$forceUpdate();
  773. },
  774. inputTotal(val) {
  775. if (val) {
  776. this.form.total = val;
  777. this.form.qualifiedNumber = val;
  778. }
  779. },
  780. handleChangeNumber(val) {
  781. this.form.sampleNumber = val;
  782. this.$emit('changeNumber', val);
  783. },
  784. //更新合格率
  785. updateQualificationRate(
  786. qualifiedNumber,
  787. noQualifiedNumber,
  788. qualificationRate,
  789. noQualificationRate
  790. ) {
  791. this.form.qualifiedNumber = qualifiedNumber;
  792. this.form.noQualifiedNumber = noQualifiedNumber;
  793. this.form.qualificationRate = qualificationRate + '%';
  794. this.form.noQualificationRate = noQualificationRate + '%';
  795. },
  796. //解决换检验方式的时候
  797. changeQualityMode(val) {
  798. if (val) {
  799. this.$emit('changeModel', val);
  800. } else {
  801. this.$emit('table2');
  802. }
  803. },
  804. //抽检需要重新计算
  805. selectResult() {
  806. console.log(this.form.qualityMode, 'this.form.qualityMode');
  807. if (this.form.qualityMode == 2) {
  808. this.$emit('quantityAssignment');
  809. }
  810. }
  811. }
  812. };
  813. </script>
  814. <style lang="scss" scoped></style>