baseInfo.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  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" />
  63. </el-form-item>
  64. </el-col>
  65. </el-row>
  66. <el-row>
  67. <el-col :span="6">
  68. <el-form-item label="工艺路线:">
  69. <el-input @click.native="openVersion" clearable v-model="form.produceRoutingName"
  70. :disabled="btnType == 'detail'" placeholder="请选择" />
  71. </el-form-item>
  72. </el-col>
  73. <el-col :span="6">
  74. <el-form-item label="工序:">
  75. <el-select style="width: 100%" v-model="form.produceTaskId" placeholder="请选择" clearable
  76. @change="produceTaskChange" :disabled="btnType == 'detail'">
  77. <el-option v-for="item in produceTaskList" :key="item.id" :label="item.name" :value="item.id">
  78. </el-option>
  79. </el-select>
  80. </el-form-item>
  81. </el-col>
  82. <el-col :span="6">
  83. <el-form-item label="合格数:" prop="qualifiedNumber">
  84. <el-input v-model="form.qualifiedNumber" :disabled="btnType == 'detail'" placeholder="请输入"></el-input>
  85. </el-form-item>
  86. </el-col>
  87. <el-col :span="6">
  88. <el-form-item label="不合格数:" prop="noQualifiedNumber">
  89. <el-input v-model="form.noQualifiedNumber" :disabled="btnType == 'detail'" placeholder="请输入"></el-input>
  90. </el-form-item>
  91. </el-col>
  92. </el-row>
  93. <el-row>
  94. <el-col :span="6">
  95. <el-form-item label="质检部门" prop="groupId">
  96. <deptSelect :disabled="btnType == 'detail'" v-model="form.groupId" @changeGroup="searchDeptNodeClick" />
  97. </el-form-item>
  98. </el-col>
  99. <el-col :span="6">
  100. <el-form-item label="质检人" prop="qualityId">
  101. <el-select :disabled="btnType == 'detail'" v-model="form.qualityId" @change="changeExecutor" size="small"
  102. style="width: 100%" filterable>
  103. <el-option v-for="item in executorList" :key="item.id" :value="item.id" :label="item.name"></el-option>
  104. </el-select>
  105. </el-form-item>
  106. </el-col>
  107. <el-col :span="6">
  108. <el-form-item label="质检时间:" prop="qualityTime">
  109. <el-date-picker class="w100" v-model="form.qualityTime" type="date" value-format="yyyy-MM-dd"
  110. :disabled="btnType == 'detail'" placeholder="请选择"></el-date-picker>
  111. </el-form-item>
  112. </el-col>
  113. <el-col :span="6">
  114. <el-form-item label="工时(h):" prop="hours">
  115. <el-input v-model="form.hours" :disabled="btnType == 'detail'"></el-input>
  116. </el-form-item>
  117. </el-col>
  118. </el-row>
  119. <el-row>
  120. <el-col :span="6">
  121. <el-form-item label="合格率:" prop="qualificationRate">
  122. <el-input type="number" v-model="form.qualificationRate" />
  123. </el-form-item>
  124. </el-col>
  125. <el-col :span="6">
  126. <el-form-item label="不合格率:" prop="noQualificationRate">
  127. <el-input type="number" v-model="form.noQualificationRate" />
  128. </el-form-item>
  129. </el-col>
  130. <el-col :span="6">
  131. <el-form-item label="总重量:" prop="totalWeight">
  132. <el-input type="number" v-model="form.totalWeight" />
  133. </el-form-item>
  134. </el-col>
  135. <el-col :span="6">
  136. <el-form-item label="取样数量:" prop="sampleNumber" :rules="{
  137. required: form.qualityMode == 2 ? true : false,
  138. message: '请输入取样数量',
  139. trigger: 'blur'
  140. }">
  141. <el-input type="number" v-model="form.sampleNumber" />
  142. </el-form-item>
  143. </el-col>
  144. </el-row>
  145. <el-row>
  146. <el-col :span="6">
  147. <el-form-item label="检验方式:" prop="qualityMode">
  148. <DictSelection dictName="取样类型" v-model="form.qualityMode" disabled></DictSelection>
  149. </el-form-item>
  150. </el-col>
  151. <el-col :span="6">
  152. <el-form-item label="质检状态:" prop="qualityResults">
  153. <el-select v-model="form.qualityResults" placeholder="请选择" style="width: 100%"
  154. :disabled="btnType == 'detail' || btnType == 'issued'" clearable>
  155. <el-option label="合格" :value=1 />
  156. <el-option label="不合格" :value=2 />
  157. </el-select>
  158. </el-form-item>
  159. </el-col>
  160. </el-row>
  161. <el-row>
  162. <el-col :span="24">
  163. <el-form-item label="备注:" prop="remark">
  164. <el-input type="textarea" v-model="form.remark" placeholder="请输入"
  165. :disabled="btnType == 'detail' || btnType == 'issued'" />
  166. </el-form-item>
  167. </el-col>
  168. </el-row>
  169. <el-row>
  170. <el-col :span="8">
  171. <el-form-item label="附件:" prop="imgUrl">
  172. <fileUpload v-model="form.imgUrl" />
  173. </el-form-item>
  174. </el-col>
  175. </el-row>
  176. <ProductionVersion ref="versionRefs" @changeProduct="changeProduct" />
  177. <EquipmentDialog ref="equipmentRefs" @choose="choose" />
  178. </el-form>
  179. </template>
  180. <script>
  181. import deptSelect from '@/components/CommomSelect/dept-select.vue';
  182. import fileUpload from '@/components/addDoc/index.vue';
  183. import ProductionVersion from './ProductionVersion.vue';
  184. import EquipmentDialog from './EquipmentDialog.vue';
  185. //接口
  186. import { getUserPage } from '@/api/system/organization';
  187. import { getProduceTaskList } from '@/api/aps';
  188. export default {
  189. components: {
  190. EquipmentDialog,
  191. ProductionVersion,
  192. deptSelect,
  193. fileUpload
  194. },
  195. props: {
  196. form: {
  197. type: Object,
  198. default: () => { }
  199. },
  200. btnType: {
  201. type: String,
  202. default: ''
  203. }
  204. },
  205. watch: {
  206. },
  207. data() {
  208. return {
  209. executorList: [],
  210. sourceList: [],
  211. rules: {
  212. productName: [
  213. { required: true, message: '请选择产品', trigger: 'change' }
  214. ],
  215. qualifiedNumber: [
  216. { required: true, message: '请输入合格数', trigger: 'blur' }
  217. ],
  218. noQualifiedNumber: [
  219. { required: true, message: '请输入不合格数', trigger: 'blur' }
  220. ],
  221. qualityTime: [
  222. { required: true, message: '请选择质检时间', trigger: 'blur' }
  223. ],
  224. groupId: [
  225. { required: true, message: '请选择质检部门', trigger: 'change' }
  226. ],
  227. qualityId: [
  228. { required: true, message: '请选择质检人', trigger: 'change' }
  229. ],
  230. qualityResults: [
  231. { required: true, message: '请选择质检状态', trigger: 'change' }
  232. ]
  233. },
  234. produceTaskList: []
  235. };
  236. },
  237. methods: {
  238. // 打开工艺路线弹窗
  239. openVersion() {
  240. this.$refs.versionRefs.open();
  241. },
  242. //工艺路线回调
  243. changeProduct(data) {
  244. this.form.produceRoutingId = data.id;
  245. this.form.produceRoutingName = data.name;
  246. this.form.produceTaskId = '';
  247. this.form.produceTaskName = '';
  248. this.getTaskList();
  249. },
  250. // 获取工序数据
  251. async getTaskList() {
  252. if (!this.form.produceRoutingId) {
  253. return;
  254. }
  255. const res = await getProduceTaskList({
  256. isDetail: true,
  257. pageNum: 1,
  258. routingId: this.form.produceRoutingId,
  259. size: -1
  260. });
  261. this.produceTaskList = res.list;
  262. },
  263. // 选择工序
  264. produceTaskChange() {
  265. if (!this.form.produceTaskId) {
  266. return;
  267. }
  268. this.form.produceTaskName = this.produceTaskList.find(
  269. (item) => item.id == this.form.produceTaskId
  270. ).name;
  271. },
  272. // 产品名称
  273. addProduct() {
  274. this.$refs.equipmentRefs.open();
  275. },
  276. choose(data) {
  277. this.form.productCode = data[0].code;
  278. this.form.productName = data[0].name;
  279. this.form.specification = data[0].specification;
  280. this.form.modelType = data[0].modelType;
  281. this.form.brandNo = data[0].brandNum;
  282. },
  283. //选择部门(搜索)
  284. searchDeptNodeClick(info, row) {
  285. if (info) {
  286. const params = { groupId: info };
  287. this.getUserList(params);
  288. this.form.groupName = row.name;
  289. } else {
  290. this.form.executeGroupId = null;
  291. }
  292. },
  293. // 获取人员
  294. async getUserList(params) {
  295. try {
  296. let data = { pageNum: 1, size: -1 };
  297. // 如果传了参数就是获取巡点检人员数据
  298. if (params) {
  299. data = Object.assign(data, params);
  300. }
  301. const res = await getUserPage(data);
  302. this.executorList = res.list;
  303. } catch (error) { }
  304. },
  305. // 人员选择
  306. changeExecutor(val) {
  307. if (val) {
  308. this.form.executeId = val;
  309. this.form.executeName = this.executorList.filter(
  310. (item) => item.id === val
  311. )[0].name;
  312. }
  313. },
  314. inputTotal(val) {
  315. if (val) {
  316. this.form.total = val;
  317. this.form.qualifiedNumber = val;
  318. }
  319. },
  320. }
  321. };
  322. </script>
  323. <style lang="scss" scoped></style>