baseInfo.vue 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487
  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="编码:" prop="code">
  6. <el-input clearable v-model="form.code" placeholder="请输入" disabled />
  7. </el-form-item>
  8. </el-col>
  9. <el-col :span="6">
  10. <el-form-item label="名称:" prop="name">
  11. <el-input clearable v-model="form.name" placeholder="请输入"
  12. :disabled="btnType == 'detail' || btnType == 'issued'" />
  13. </el-form-item>
  14. </el-col>
  15. <el-col :span="6">
  16. <el-form-item label="检验方式:" prop="qualityMode">
  17. <DictSelection dictName="取样类型" v-model="form.qualityMode" clearable
  18. :disabled="btnType == 'detail' || btnType == 'issued'">
  19. </DictSelection>
  20. </el-form-item>
  21. </el-col>
  22. <el-col :span="6">
  23. <el-form-item label="检验标准" prop="inspectionStandards">
  24. <!-- 计量 计重 -->
  25. <el-select style="width: 100%" v-model="form.inspectionStandards" placeholder="请选择">
  26. <el-option v-for="item in inspectionStandardsList" :label="item.label" :value="item.value"
  27. :key="item.value">
  28. </el-option>
  29. </el-select>
  30. </el-form-item>
  31. </el-col>
  32. </el-row>
  33. <el-row>
  34. <el-col :span="6">
  35. <el-form-item label="自动派单:" prop="autoOrder">
  36. <el-select v-model="form.autoOrder" placeholder="请选择" style="width: 100%"
  37. :disabled="btnType == 'detail' || btnType == 'issued'" clearable>
  38. <el-option label="是" :value="1" />
  39. <el-option label="否" :value="0" />
  40. </el-select>
  41. </el-form-item>
  42. </el-col>
  43. <el-col :span="6">
  44. <el-form-item label="执行部门:" prop="groupId">
  45. <deptSelect :disabled="btnType == 'detail'" v-model="form.groupId" @changeGroup="searchDeptNodeClick" />
  46. </el-form-item>
  47. </el-col>
  48. <el-col :span="6">
  49. <el-form-item label="执行人员:" prop="executeId">
  50. <el-select :disabled="btnType == 'detail'" v-model="form.executeId" @change="changeExecutor" filterable
  51. style="width: 100%">
  52. <el-option v-for="item in executorList" :key="item.id" :value="item.id" :label="item.name"></el-option>
  53. </el-select>
  54. </el-form-item>
  55. </el-col>
  56. <el-col :span="6">
  57. <el-form-item label="开始时间:" prop="planStartTime">
  58. <el-date-picker :disabled="btnType == 'detail'" class="w100" v-model="form.planStartTime" type="date"
  59. value-format="yyyy-MM-dd" placeholder="请输入"></el-date-picker>
  60. </el-form-item>
  61. </el-col>
  62. </el-row>
  63. <div style="text-align: right;margin-bottom: 22px;">
  64. <div @click="toggleExpand">
  65. <div v-if="isExpanded"><i class="el-icon-arrow-up"></i>收起</div>
  66. <div v-if="!isExpanded"><i class="el-icon-arrow-down"></i>展开更多</div>
  67. </div>
  68. </div>
  69. <div v-if="isExpanded">
  70. <el-row>
  71. <el-col :span="6">
  72. <el-form-item label="结束时间:" prop="planEndTime">
  73. <el-date-picker :disabled="btnType == 'detail'" class="w100" v-model="form.planEndTime" type="date"
  74. value-format="yyyy-MM-dd" placeholder="请输入"></el-date-picker>
  75. </el-form-item>
  76. </el-col>
  77. <el-col :span="6">
  78. <el-form-item label="类型:" prop="type">
  79. <DictSelection dictName="质检计划类型" v-model="form.type" clearable @change="typeChange"
  80. :disabled="btnType == 'detail' || btnType == 'issued'"></DictSelection>
  81. </el-form-item>
  82. </el-col>
  83. <el-col :span="6">
  84. <el-form-item label="计划来源:" prop="planSource">
  85. <el-select v-model="form.planSource" placeholder="请选择" style="width: 100%" clearable
  86. @change="planSourceChange" :disabled="btnType == 'detail' || btnType == 'issued'">
  87. <el-option :label="item.label" v-for="item in sourceList" :key="item.value" :value="item.value" />
  88. </el-select>
  89. </el-form-item>
  90. </el-col>
  91. <el-col :span="6">
  92. <el-form-item label="来源编码:" prop="planSourceCode">
  93. <el-input v-model="form.planSourceCode" disabled />
  94. </el-form-item>
  95. </el-col>
  96. </el-row>
  97. <el-row>
  98. <el-col :span="6">
  99. <el-form-item label="名称:" prop="productName">
  100. <el-input v-model="form.productName" disabled />
  101. </el-form-item>
  102. </el-col>
  103. <el-col :span="6">
  104. <el-form-item label="编码:" prop="productCode">
  105. <el-input v-model="form.productCode" disabled />
  106. </el-form-item>
  107. </el-col>
  108. <el-col :span="6">
  109. <el-form-item label="批次号:" prop="batchNo">
  110. <el-input v-model="form.batchNo" disabled />
  111. </el-form-item>
  112. </el-col>
  113. <el-col :span="6">
  114. <el-form-item label="规格:" prop="specification">
  115. <el-input v-model="form.specification" disabled />
  116. </el-form-item>
  117. </el-col>
  118. </el-row>
  119. <el-row>
  120. <el-col :span="6">
  121. <el-form-item label="型号:" prop="modelType">
  122. <el-input v-model="form.modelType" disabled />
  123. </el-form-item>
  124. </el-col>
  125. <el-col :span="6">
  126. <el-form-item label="牌号:" prop="brandNo">
  127. <el-input v-model="form.brandNo" disabled />
  128. </el-form-item>
  129. </el-col>
  130. <el-col :span="6">
  131. <el-form-item label="数量:" prop="productNumber">
  132. <el-input type="number" v-model="form.productNumber" disabled>
  133. <template #append>{{ categoryInfo.measuringUnit }}</template>
  134. </el-input>
  135. </el-form-item>
  136. </el-col>
  137. <el-col :span="6">
  138. <el-form-item label="工序:" prop="produceTaskName">
  139. <el-input v-model="form.produceTaskName" disabled />
  140. </el-form-item>
  141. </el-col>
  142. </el-row>
  143. <el-row>
  144. <el-col :span="6">
  145. <el-form-item label="合格品数量:" prop="qualifiedNumber">
  146. <el-input type="number" v-model="form.qualifiedNumber" disabled>
  147. <template #append>{{ categoryInfo.measuringUnit }}</template>
  148. </el-input>
  149. </el-form-item>
  150. </el-col>
  151. <el-col :span="6">
  152. <el-form-item label="不合格品数量:" prop="unqualifiedNumber">
  153. <el-input type="number" v-model="form.unqualifiedNumber" disabled>
  154. <template #append>{{ categoryInfo.measuringUnit }}</template>
  155. </el-input>
  156. </el-form-item>
  157. </el-col>
  158. <el-col :span="6">
  159. <el-form-item label="合格率:" prop="qualificationRate">
  160. <el-input v-model="form.qualificationRate" :disabled="btnType == 'detail' || btnType == 'issued'" />
  161. </el-form-item>
  162. </el-col>
  163. <el-col :span="6">
  164. <el-form-item label="总重量:" prop="totalWeight">
  165. <el-input type="number" v-model="form.totalWeight" :disabled="btnType == 'detail' || btnType == 'issued'">
  166. <template #append>{{ categoryInfo.weightUnit }}</template>
  167. </el-input>
  168. </el-form-item>
  169. </el-col>
  170. </el-row>
  171. <el-row>
  172. <el-col :span="6" v-if="form.qualityMode == 2">
  173. <el-form-item label="取样数量:" prop="sampleNumber" :rules="{
  174. required: form.qualityMode == 2 ? true : false,
  175. message: '请输入取样数量',
  176. trigger: 'blur'
  177. }">
  178. <div style="display: flex;align-items: center;justify-content: space-between;">
  179. <el-input type="number" v-model="form.sampleNumber" disabled style="width: calc(100% - 90px)">
  180. </el-input>
  181. <DictSelection dictName="计量单位" clearable v-model="form.sampleMeasureUnit" disabled size="mini"
  182. style="width: 90px;margin-left: 12px;">
  183. </DictSelection>
  184. </div>
  185. </el-form-item>
  186. </el-col>
  187. <el-col :span="6">
  188. <el-form-item label="抽样比例:" prop="sampleProportion">
  189. <el-input v-model="form.sampleProportion" :disabled="btnType == 'detail' || btnType == 'issued'">
  190. <template #append>%</template>
  191. </el-input>
  192. </el-form-item>
  193. </el-col>
  194. </el-row>
  195. <el-row>
  196. <el-col :span="24">
  197. <el-form-item label="备注:" prop="remark">
  198. <el-input type="textarea" v-model="form.remark" placeholder="请输入"
  199. :disabled="btnType == 'detail' || 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="accessory">
  206. <fileUpload v-model="form.accessory" :type="btnType == 'detail' ? 'view' : ''" />
  207. </el-form-item>
  208. </el-col>
  209. </el-row>
  210. </div>
  211. <warehousing ref="warehousingRef" @choose="handleChoose" />
  212. <productionPlan ref="productionPlanRef" @choose="handleChoose" />
  213. <workOrder ref="workOrderRef" @choose="handleChoose" />
  214. <produceOrder ref="produceOrderRef" @choose="handleChoose" />
  215. <EquipmentDialog ref="equipmentRefs" @choose="handleChoose" :type="1" :treeIds="['9', '1']" />
  216. </el-form>
  217. </template>
  218. <script>
  219. import deptSelect from '@/components/CommomSelect/dept-select.vue';
  220. import fileUpload from '@/components/addDoc/index.vue';
  221. import warehousing from './warehousing';
  222. import productionPlan from './productionPlan';
  223. import workOrder from './workOrder';
  224. import produceOrder from './produceOrder';
  225. import EquipmentDialog from '@/views/inspectionWork/components/EquipmentDialog';
  226. //接口
  227. import { getUserPage } from '@/api/system/organization';
  228. import { getByCode } from '@/api/system/dictionary-data';
  229. import { rules } from 'eslint-config-prettier';
  230. import { getDetailInfo } from '@/api/inspectionPlan/index.js';
  231. export default {
  232. components: {
  233. EquipmentDialog,
  234. produceOrder,
  235. workOrder,
  236. productionPlan,
  237. warehousing,
  238. deptSelect,
  239. fileUpload
  240. },
  241. props: {
  242. form: {
  243. type: Object,
  244. default: () => { }
  245. },
  246. btnType: {
  247. type: String,
  248. default: ''
  249. },
  250. packingLists: {
  251. type: Array,
  252. default: () => []
  253. },
  254. },
  255. watch: {
  256. 'form.qualityMode': {
  257. handler(newVal) {
  258. if (newVal) {
  259. this.$emit('changeModel', newVal);
  260. } else {
  261. console.log('清空样品清单');
  262. this.$emit('table2');
  263. }
  264. },
  265. immediate: false
  266. },
  267. 'form.type': {
  268. handler(newVal) {
  269. if (!newVal) {
  270. this.form.planSource = '';
  271. this.form.planSourceCode = '';
  272. this.form.productName = '';
  273. this.form.productCode = '';
  274. this.form.batchNo = '';
  275. this.form.specification = '';
  276. this.form.modelType = '';
  277. this.form.brandNo = '';
  278. this.form.productNumber = '';
  279. this.form.qualifiedNumber = '';
  280. this.form.unqualifiedNumber = '';
  281. this.form.qualificationRate = '';
  282. this.form.totalWeight = '';
  283. this.form.sampleNumber = '';
  284. this.sourceList = [];
  285. this.$emit('resetTable');
  286. }
  287. },
  288. immediate: false
  289. },
  290. 'form.planSource': {
  291. handler(newVal) {
  292. if (!newVal) {
  293. this.form.planSource = '';
  294. this.form.planSourceCode = '';
  295. this.form.productName = '';
  296. this.form.productCode = '';
  297. this.form.batchNo = '';
  298. this.form.specification = '';
  299. this.form.modelType = '';
  300. this.form.brandNo = '';
  301. this.form.productNumber = '';
  302. this.form.qualifiedNumber = '';
  303. this.form.unqualifiedNumber = '';
  304. this.form.qualificationRate = '';
  305. this.form.totalWeight = '';
  306. this.form.sampleNumber = '';
  307. this.$emit('resetTable');
  308. }
  309. },
  310. immediate: false
  311. }
  312. },
  313. data() {
  314. return {
  315. executorList: [],
  316. sourceList: [],
  317. inspectionStandardsList: [],
  318. rules: {
  319. name: [{ required: true, message: '请输入', trigger: 'blur' }],
  320. qualityMode: [
  321. { required: true, message: '请选择检验方式', trigger: 'blur' }
  322. ],
  323. type: [{ required: true, message: '请选择类型', trigger: 'blur' }],
  324. groupId: [
  325. { required: true, message: '请选择执行部门', trigger: 'blur' }
  326. ],
  327. executeId: [
  328. { required: true, message: '请选择执行人员:', trigger: 'blur' }
  329. ]
  330. },
  331. isExpanded: false, // 控制展开/收起状态
  332. categoryInfo: {},
  333. };
  334. },
  335. created() {
  336. this.getDictListIqoCode('iqo_code');
  337. },
  338. methods: {
  339. toggleExpand(val) {
  340. this.isExpanded = !this.isExpanded;
  341. },
  342. // 获取检验标准
  343. async getDictListIqoCode(code) {
  344. let { data: res } = await getByCode(code);
  345. this.inspectionStandardsList = res.map((item) => {
  346. let values = Object.keys(item);
  347. return {
  348. value: Number(values[0]),
  349. label: item[values[0]]
  350. };
  351. });
  352. },
  353. //质检计划类型
  354. planChange(value) {
  355. if (value == 1) {
  356. this.sourceList = [{ label: '采购收货单', value: '1' }];
  357. } else if (value == 2) {
  358. this.sourceList = [
  359. { label: '生产计划', value: '2' },
  360. { label: '生产订单', value: '3' },
  361. { label: '生产工单', value: '4' }
  362. ];
  363. }
  364. },
  365. //选择部门(搜索)
  366. searchDeptNodeClick(info, row) {
  367. if (info) {
  368. const params = { groupId: info };
  369. this.getUserList(params);
  370. this.form.groupName = row.name;
  371. } else {
  372. this.form.executeGroupId = null;
  373. }
  374. },
  375. // 获取审核人列表、巡点检人员
  376. async getUserList(params) {
  377. try {
  378. let data = { pageNum: 1, size: -1 };
  379. // 如果传了参数就是获取巡点检人员数据
  380. if (params) {
  381. data = Object.assign(data, params);
  382. }
  383. const res = await getUserPage(data);
  384. this.executorList = res.list;
  385. } catch (error) { }
  386. },
  387. // 执行人选择
  388. changeExecutor(val) {
  389. if (val) {
  390. this.form.executeId = val;
  391. this.form.executeName = this.executorList.filter(
  392. (item) => item.id === val
  393. )[0].name;
  394. }
  395. },
  396. //计划来源选择
  397. planSourceChange(val) {
  398. if (val) {
  399. this.addProduct();
  400. }
  401. },
  402. addProduct() {
  403. if (this.form.planSource == 1) {
  404. this.$refs.warehousingRef.open();
  405. } else if (this.form.planSource == 2) {
  406. this.$refs.productionPlanRef.open();
  407. } else if (this.form.planSource == 3) {
  408. this.$refs.workOrderRef.open();
  409. } else if (this.form.planSource == 4) {
  410. this.$refs.produceOrderRef.open();
  411. } else {
  412. this.$refs.equipmentRefs.open();
  413. }
  414. },
  415. //根据类型获取计划来源下拉
  416. typeChange(val) {
  417. if (val == 1) {
  418. this.sourceList = [{ label: '采购收货单', value: '1' }];
  419. } else if (val == 2) {
  420. this.sourceList = [
  421. { label: '生产计划', value: '2' },
  422. { label: '生产订单', value: '3' },
  423. { label: '生产工单', value: '4' }
  424. ];
  425. }
  426. },
  427. // 根据来源得到产品
  428. handleChoose(val) {
  429. if (!val) return;
  430. this.form.planSourceId = val.id;
  431. this.form.planSourceCode = val.receiveNo;
  432. this.form.supplierName = val.supplierName;
  433. this.form.supplierMark = val.supplierMark;
  434. this.form.productName = val.productName;
  435. this.form.productCode = val.productCode;
  436. this.form.batchNo = val.batchNo;
  437. this.form.specification = val.specification;
  438. this.form.modelType = val.modelType;
  439. this.form.brandNo = val.brandNo;
  440. this.form.productNumber = val.totalCount;
  441. this.form.qualifiedNumber = val.qualifiedNumber;
  442. this.form.unqualifiedNumber = val.unqualifiedNumber;
  443. this.form.qualificationRate = val.qualificationRate;
  444. this.form.totalWeight = val.totalWeight;
  445. this.form.sampleNumber = val.sampleNumber;
  446. this.form.inspectionStandards = val.inspectionStandards;
  447. this.form.produceTaskName = val.taskName;
  448. this.form.produceTaskId = val.taskId;
  449. this.form.productId = val.productId;
  450. let receiveNo = val.receiveNo;
  451. let categoryCode = val.productCode;
  452. let categoryid = val.productId;
  453. let batchNo = val.batchNo;
  454. let productCategoryId = val.productCategoryId;
  455. let productCategoryName = val.productCategoryName;
  456. if (receiveNo && categoryCode && categoryid) {
  457. this.$emit('getList', receiveNo, categoryCode, productCategoryId, productCategoryName, categoryid, batchNo, val.supplierName, val.supplierMark);
  458. }
  459. this.getProductDetails(this.form.productId)
  460. },
  461. //获取产品详情信息-来自主数据
  462. async getProductDetails(val) {
  463. const data = await getDetailInfo(val)
  464. this.categoryInfo = data.category
  465. // this.$emit('getCategoryInfo', data)
  466. },
  467. getsampleMeasureUnit(val) {
  468. this.$set(this.form, 'sampleMeasureUnit', val);
  469. }
  470. }
  471. };
  472. </script>
  473. <style lang="scss" scoped>
  474. ::v-deep .el-form-item .el-form-item--medium .more {
  475. margin: 0 !important;
  476. }
  477. </style>