baseInfo.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414
  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 :maxlength="20" v-model="form.code" disabled placeholder="请输入" />
  7. </el-form-item>
  8. </el-col>
  9. <!-- <el-col :span="6">
  10. <el-form-item label="质检类型:" prop="qualityType">
  11. <DictSelection
  12. dictName="质检计划类型"
  13. v-model="form.qualityType"
  14. :disabled="btnType == 'detail'"
  15. ></DictSelection>
  16. </el-form-item>
  17. </el-col>
  18. <el-col :span="6">
  19. <el-form-item label="质检方式:" prop="qualityMode">
  20. <DictSelection
  21. dictName="取样类型"
  22. v-model="form.qualityMode"
  23. clearable
  24. :disabled="btnType == 'detail'"
  25. ></DictSelection>
  26. </el-form-item>
  27. </el-col> -->
  28. <el-col :span="6">
  29. <el-form-item label="产品名称:" prop="productName">
  30. <el-input v-model="form.productName" @click.native="addProduct" readonly placeholder="请选择" />
  31. </el-form-item>
  32. </el-col>
  33. <el-col :span="6">
  34. <el-form-item label="产品编码:" prop="productCode">
  35. <el-input v-model="form.productCode" disabled />
  36. </el-form-item>
  37. </el-col>
  38. <el-col :span="6">
  39. <el-form-item label="批次号:" prop=" batchNo">
  40. <el-input v-model="form.batchNo" disabled />
  41. </el-form-item>
  42. </el-col>
  43. </el-row>
  44. <el-row>
  45. <el-col :span="6">
  46. <el-form-item label="规格:" prop="specification">
  47. <el-input v-model="form.specification" disabled />
  48. </el-form-item>
  49. </el-col>
  50. <el-col :span="6">
  51. <el-form-item label="型号:" prop="modelType">
  52. <el-input v-model="form.modelType" disabled />
  53. </el-form-item>
  54. </el-col>
  55. <el-col :span="6">
  56. <el-form-item label="牌号:" prop="brandNo">
  57. <el-input v-model="form.brandNo" disabled />
  58. </el-form-item>
  59. </el-col>
  60. <el-col :span="6">
  61. <el-form-item label="总数量:" prop="total">
  62. <el-input type="number" v-model="form.total" @input="inputTotal" disabled />
  63. </el-form-item>
  64. </el-col>
  65. </el-row>
  66. <div style="text-align: right;margin-bottom: 22px;">
  67. <div @click="toggleExpand">
  68. <div v-if="isExpanded"><i class="el-icon-arrow-up"></i>收起</div>
  69. <div v-if="!isExpanded"><i class="el-icon-arrow-down"></i>展开更多</div>
  70. </div>
  71. </div>
  72. <div v-if="isExpanded">
  73. <el-row>
  74. <el-col :span="6">
  75. <el-form-item label="质检部门" prop="groupId">
  76. <deptSelect :disabled="btnType == 'detail'" v-model="form.groupId" @changeGroup="searchDeptNodeClick" />
  77. </el-form-item>
  78. </el-col>
  79. <el-col :span="6">
  80. <el-form-item label="质检人" prop="qualityId">
  81. <el-select :disabled="btnType == 'detail'" v-model="form.qualityId" @change="changeExecutor" size="small"
  82. style="width: 100%" filterable>
  83. <el-option v-for="item in executorList" :key="item.id" :value="item.id" :label="item.name"></el-option>
  84. </el-select>
  85. </el-form-item>
  86. </el-col>
  87. <el-col :span="6">
  88. <el-form-item label="质检时间:" prop="qualityTime">
  89. <el-date-picker class="w100" v-model="form.qualityTime" type="date" value-format="yyyy-MM-dd"
  90. :disabled="btnType == 'detail'" placeholder="请选择"></el-date-picker>
  91. </el-form-item>
  92. </el-col>
  93. <el-col :span="6">
  94. <el-form-item label="工时(h):" prop="hours">
  95. <el-input v-model="form.hours" :disabled="btnType == 'detail'"></el-input>
  96. </el-form-item>
  97. </el-col>
  98. </el-row>
  99. <el-row>
  100. <el-col :span="6">
  101. <el-form-item label="合格数:" prop="qualifiedNumber">
  102. <el-input v-model="form.qualifiedNumber" placeholder="请输入"></el-input>
  103. </el-form-item>
  104. </el-col>
  105. <el-col :span="6">
  106. <el-form-item label="不合格数:" prop="noQualifiedNumber">
  107. <el-input v-model="form.noQualifiedNumber" placeholder="请输入"></el-input>
  108. </el-form-item>
  109. </el-col>
  110. <el-col :span="6">
  111. <el-form-item label="合格率:" prop="qualificationRate">
  112. <el-input v-model="form.qualificationRate" disabled />
  113. </el-form-item>
  114. </el-col>
  115. <el-col :span="6">
  116. <el-form-item label="不合格率:" prop="noQualificationRate">
  117. <el-input v-model="form.noQualificationRate" disabled />
  118. </el-form-item>
  119. </el-col>
  120. </el-row>
  121. <el-row>
  122. <el-col :span="6">
  123. <el-form-item label="总重量:" prop="totalWeight">
  124. <el-input type="number" v-model="form.totalWeight" />
  125. </el-form-item>
  126. </el-col>
  127. <el-col :span="6">
  128. <el-form-item label="检验标准" prop="inspectionStandards">
  129. <!-- 计量 计重 -->
  130. <el-select style="width: 100%" v-model="form.inspectionStandards" placeholder="请选择"
  131. :disabled="parseInt(qualityType1) == 1">
  132. <el-option v-for="item in inspectionStandardsList" :label="item.label" :value="item.value"
  133. :key="item.value">
  134. </el-option>
  135. </el-select>
  136. </el-form-item>
  137. </el-col>
  138. <el-col :span="6">
  139. <el-form-item label="检验方式:" prop="qualityMode">
  140. <!-- <DictSelection dictName="取样类型" v-model="form.qualityMode" :disabled="qualityType == 1"></DictSelection> -->
  141. <el-select style="width: 100%" v-model="form.qualityMode" placeholder="请选择"
  142. :disabled="parseInt(qualityType1) == 1">
  143. <el-option v-for="item in qualityModeList" :label="item.label" :value="item.value" :key="item.value">
  144. </el-option>
  145. </el-select>
  146. </el-form-item>
  147. </el-col>
  148. <el-col :span="6">
  149. <el-form-item label="取样数量:" prop="sampleNumber" :rules="{
  150. required: form.qualityMode == 2 ? true : false,
  151. message: '请输入取样数量',
  152. trigger: 'blur'
  153. }" v-if="form.qualityMode == 2">
  154. <div style="display: flex;align-items: center;justify-content: space-between;">
  155. <el-input type="number"
  156. :disabled="form.qualityMode == null || form.qualityMode == 1 || (form.qualityMode == 2 && form.sampleNumber) ? true : false"
  157. v-model="form.sampleNumber" @change="handleChangeNumber" style="width: calc(100% - 90px)" />
  158. <DictSelection dictName="计量单位" clearable v-model="form.sampleMeasureUnit" disabled size="mini"
  159. style="width: 90px;margin-left: 12px;">
  160. </DictSelection>
  161. </div>
  162. </el-form-item>
  163. </el-col>
  164. </el-row>
  165. <el-row>
  166. <el-col :span="6" v-if="parseInt(qualityType1) == 2">
  167. <el-form-item label="工艺路线:">
  168. <el-input @click.native="openVersion" clearable v-model="form.produceRoutingName"
  169. :disabled="btnType == 'detail'" placeholder="请选择" />
  170. </el-form-item>
  171. </el-col>
  172. <el-col :span="6" v-if="parseInt(qualityType1) == 2">
  173. <el-form-item label="工序:">
  174. <el-select style="width: 100%" v-model="form.produceTaskId" placeholder="请选择" clearable
  175. @change="produceTaskChange" :disabled="btnType == 'detail'">
  176. <el-option v-for="item in produceTaskList" :key="item.id" :label="item.name" :value="item.id">
  177. </el-option>
  178. </el-select>
  179. </el-form-item>
  180. </el-col>
  181. <el-col :span="6">
  182. <el-form-item label="合格证号:" prop="certificateNumber">
  183. <el-input v-model="form.certificateNumber" :disabled="btnType == 'detail'" placeholder="请输入"></el-input>
  184. </el-form-item>
  185. </el-col>
  186. <el-col :span="6">
  187. <el-form-item label="质检结果:" prop="qualityResults">
  188. <el-select v-model="form.qualityResults" placeholder="请选择" style="width: 100%"
  189. :disabled="btnType == 'issued'" clearable>
  190. <el-option label="合格" :value=1 />
  191. <el-option label="不合格" :value=2 />
  192. </el-select>
  193. </el-form-item>
  194. </el-col>
  195. </el-row>
  196. <el-row>
  197. <el-col :span="24">
  198. <el-form-item label="备注:" prop="remark">
  199. <el-input type="textarea" v-model="form.remark" placeholder="请输入" :disabled="btnType == 'issued'" />
  200. </el-form-item>
  201. </el-col>
  202. </el-row>
  203. <el-row>
  204. <el-col :span="8">
  205. <el-form-item label="附件:" prop="imgUrl">
  206. <fileUpload v-model="form.imgUrl" :type="btnType == 'detail' ? 'view' : ''" />
  207. </el-form-item>
  208. </el-col>
  209. </el-row>
  210. </div>
  211. <ProductionVersion ref="versionRefs" @changeProduct="changeProduct" />
  212. <EquipmentDialog ref="equipmentRefs" @choose="choose" />
  213. </el-form>
  214. </template>
  215. <script>
  216. import deptSelect from '@/components/CommomSelect/dept-select.vue';
  217. import fileUpload from '@/components/addDoc/index.vue';
  218. import ProductionVersion from './ProductionVersion.vue';
  219. import EquipmentDialog from './EquipmentDialog.vue';
  220. //接口
  221. import { getUserPage } from '@/api/system/organization';
  222. import { getProduceTaskList } from '@/api/aps';
  223. import { getByCode } from "@/api/system/dictionary-data";
  224. export default {
  225. components: {
  226. EquipmentDialog,
  227. ProductionVersion,
  228. deptSelect,
  229. fileUpload
  230. },
  231. props: {
  232. form: {
  233. type: Object,
  234. default: () => { }
  235. },
  236. btnType: {
  237. type: String,
  238. default: ''
  239. },
  240. qualityType1: {
  241. type: String,
  242. default: ''
  243. }
  244. },
  245. watch: {
  246. 'form.qualityMode': {
  247. handler(newVal) {
  248. if (newVal) {
  249. this.$emit('changeModel', newVal);
  250. } else {
  251. console.log('清空样品清单');
  252. // this.$emit('table2');
  253. }
  254. },
  255. immediate: false
  256. },
  257. },
  258. data() {
  259. return {
  260. executorList: [],
  261. sourceList: [],
  262. rules: {
  263. productName: [
  264. { required: true, message: '请选择产品', trigger: 'change' }
  265. ],
  266. qualifiedNumber: [
  267. { required: true, message: '请输入合格数', trigger: 'blur' }
  268. ],
  269. noQualifiedNumber: [
  270. { required: true, message: '请输入不合格数', trigger: 'blur' }
  271. ],
  272. qualityTime: [
  273. { required: true, message: '请选择质检时间', trigger: 'blur' }
  274. ],
  275. groupId: [
  276. { required: true, message: '请选择质检部门', trigger: 'change' }
  277. ],
  278. qualityId: [
  279. { required: true, message: '请选择质检人', trigger: 'change' }
  280. ],
  281. qualityResults: [
  282. { required: true, message: '请选择质检状态', trigger: 'change' }
  283. ]
  284. },
  285. produceTaskList: [],
  286. inspectionStandardsList: [],
  287. qualityModeList: [],
  288. isExpanded: false
  289. };
  290. },
  291. created() {
  292. this.getDictListIqoCode('iqo_code');
  293. this.getQualityModeList('quality_method_code');
  294. },
  295. methods: {
  296. toggleExpand() {
  297. this.isExpanded = !this.isExpanded;
  298. },
  299. async getDictListIqoCode(code) {
  300. let { data: res } = await getByCode(code);
  301. this.inspectionStandardsList = res.map((item) => {
  302. let values = Object.keys(item);
  303. return {
  304. value: Number(values[0]),
  305. label: item[values[0]]
  306. };
  307. });
  308. },
  309. async getQualityModeList(code) {
  310. let { data: res } = await getByCode(code);
  311. this.qualityModeList = res.map((item) => {
  312. let values = Object.keys(item);
  313. return {
  314. value: Number(values[0]),
  315. label: item[values[0]]
  316. };
  317. });
  318. },
  319. // 打开工艺路线弹窗
  320. openVersion() {
  321. this.$refs.versionRefs.open();
  322. },
  323. //工艺路线回调
  324. changeProduct(data) {
  325. this.form.produceRoutingId = data.id;
  326. this.form.produceRoutingName = data.name;
  327. this.form.produceTaskId = '';
  328. this.form.produceTaskName = '';
  329. this.getTaskList();
  330. },
  331. // 获取工序数据
  332. async getTaskList() {
  333. if (!this.form.produceRoutingId) {
  334. return;
  335. }
  336. const res = await getProduceTaskList({
  337. isDetail: true,
  338. pageNum: 1,
  339. routingId: this.form.produceRoutingId,
  340. size: -1
  341. });
  342. this.produceTaskList = res?.list;
  343. },
  344. // 选择工序
  345. produceTaskChange() {
  346. if (!this.form.produceTaskId) {
  347. return;
  348. }
  349. this.form.produceTaskName = this.produceTaskList.find(
  350. (item) => item.id == this.form.produceTaskId
  351. ).name;
  352. },
  353. // 产品名称
  354. addProduct() {
  355. this.$refs.equipmentRefs.open();
  356. },
  357. choose(data) {
  358. this.form.productCode = data[0].code;
  359. this.form.productName = data[0].name;
  360. this.form.specification = data[0].specification;
  361. this.form.modelType = data[0].modelType;
  362. this.form.brandNo = data[0].brandNum;
  363. },
  364. //选择部门(搜索)
  365. searchDeptNodeClick(info, row) {
  366. if (info) {
  367. const params = { groupId: info };
  368. this.getUserList(params);
  369. this.form.groupName = row.name;
  370. } else {
  371. this.form.executeGroupId = null;
  372. }
  373. },
  374. // 获取人员
  375. async getUserList(params) {
  376. try {
  377. let data = { pageNum: 1, size: -1 };
  378. // 如果传了参数就是获取巡点检人员数据
  379. if (params) {
  380. data = Object.assign(data, params);
  381. }
  382. const res = await getUserPage(data);
  383. this.executorList = res.list;
  384. } catch (error) { }
  385. },
  386. // 人员选择
  387. changeExecutor(val) {
  388. if (val) {
  389. this.form.executeId = val;
  390. this.form.executeName = this.executorList.filter(
  391. (item) => item.id === val
  392. )[0].name;
  393. }
  394. },
  395. inputTotal(val) {
  396. if (val) {
  397. this.form.total = val;
  398. this.form.qualifiedNumber = val;
  399. }
  400. },
  401. handleChangeNumber(val) {
  402. this.form.sampleNumber = val;
  403. console.log(val);
  404. this.$emit('changeNumber', val);
  405. },
  406. }
  407. };
  408. </script>
  409. <style lang="scss" scoped></style>