edit.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553
  1. <!-- 用户编辑弹窗 -->
  2. <template>
  3. <el-dialog
  4. class="ele-dialog-form"
  5. :title="title"
  6. :visible.sync="visible"
  7. :before-close="handleClose"
  8. :close-on-click-modal="false"
  9. :close-on-press-escape="false"
  10. width="1280px"
  11. >
  12. <el-form ref="form" :model="form" :rules="rules" label-width="120px">
  13. <el-row>
  14. <el-col :span="8">
  15. <el-form-item label="编码:" prop="code">
  16. <el-input
  17. clearable
  18. v-model="form.code"
  19. placeholder="请输入"
  20. disabled
  21. />
  22. </el-form-item>
  23. </el-col>
  24. <el-col :span="8">
  25. <el-form-item label="名称:" prop="name">
  26. <el-input
  27. clearable
  28. v-model="form.name"
  29. placeholder="请输入"
  30. :disabled="type == 'detail' || type == 'issued'"
  31. />
  32. </el-form-item>
  33. </el-col>
  34. <el-col :span="8">
  35. <el-form-item label="类型:" prop="type">
  36. <DictSelection
  37. dictName="质检计划类型"
  38. @change="planChange"
  39. v-model="form.type"
  40. clearable
  41. :disabled="type == 'detail' || type == 'issued'"
  42. ></DictSelection>
  43. </el-form-item>
  44. </el-col>
  45. <el-col :span="8">
  46. <el-form-item label="取样类型:" prop="qualityMode">
  47. <DictSelection
  48. dictName="取样类型"
  49. v-model="form.qualityMode"
  50. clearable
  51. :disabled="type == 'detail' || type == 'issued'"
  52. ></DictSelection>
  53. </el-form-item>
  54. </el-col>
  55. <el-col :span="8">
  56. <el-form-item label="计划来源:" prop="planSource">
  57. <el-select
  58. v-model="form.planSource"
  59. placeholder="请选择"
  60. style="width: 100%"
  61. clearable
  62. @change="planSourceChange"
  63. :disabled="type == 'detail' || type == 'issued'"
  64. >
  65. <el-option
  66. :label="item.label"
  67. v-for="item in sourceList"
  68. :key="item.value"
  69. :value="item.value"
  70. />
  71. </el-select>
  72. </el-form-item>
  73. </el-col>
  74. <el-col :span="8">
  75. <el-form-item label="计划来源编码:" prop="planSourceCode">
  76. <el-input v-model="form.planSourceCode" disabled />
  77. </el-form-item>
  78. </el-col>
  79. <el-col :span="8">
  80. <el-form-item label="自动派单:" prop="autoOrder">
  81. <el-select
  82. v-model="form.autoOrder"
  83. placeholder="请选择"
  84. style="width: 100%"
  85. :disabled="type == 'detail' || type == 'issued'"
  86. >
  87. <el-option label="是" :value="1" />
  88. <el-option label="否" :value="0" />
  89. </el-select>
  90. </el-form-item>
  91. </el-col>
  92. <el-col :span="8">
  93. <el-form-item
  94. label="执行部门"
  95. prop="groupId"
  96. :rules="{
  97. required: form.autoOrder || type == 'issued' ? true : false,
  98. message: '请选择',
  99. trigger: 'blur'
  100. }"
  101. >
  102. <deptSelect
  103. :disabled="type == 'detail'"
  104. v-model="form.groupId"
  105. @changeGroup="searchDeptNodeClick"
  106. />
  107. </el-form-item>
  108. </el-col>
  109. <el-col :span="8">
  110. <el-form-item
  111. label="执行人员"
  112. prop="executeId"
  113. :rules="{
  114. required: form.autoOrder || type == 'issued' ? true : false,
  115. message: '请选择',
  116. trigger: 'blur'
  117. }"
  118. >
  119. <el-select
  120. :disabled="type == 'detail'"
  121. v-model="form.executeId"
  122. @change="changeExecutor"
  123. size="small"
  124. style="width: 100%"
  125. filterable
  126. >
  127. <el-option
  128. v-for="item in executorList"
  129. :key="item.id"
  130. :value="item.id"
  131. :label="item.name"
  132. ></el-option>
  133. </el-select>
  134. </el-form-item>
  135. </el-col>
  136. <el-col :span="8">
  137. <el-form-item label="计划开始时间:" prop="planStartTime">
  138. <el-date-picker
  139. :disabled="type == 'detail'"
  140. class="w100"
  141. v-model="form.planStartTime"
  142. type="date"
  143. value-format="yyyy-MM-dd"
  144. ></el-date-picker>
  145. </el-form-item>
  146. </el-col>
  147. <el-col :span="8">
  148. <el-form-item label="计划结束时间:" prop="planEndTime">
  149. <el-date-picker
  150. :disabled="type == 'detail'"
  151. class="w100"
  152. v-model="form.planEndTime"
  153. type="date"
  154. value-format="yyyy-MM-dd"
  155. ></el-date-picker>
  156. </el-form-item>
  157. </el-col>
  158. <el-col :span="8">
  159. <el-form-item label="附件:" prop="accessory">
  160. <fileUpload
  161. v-model="form.accessory"
  162. />
  163. </el-form-item>
  164. </el-col>
  165. </el-row>
  166. <el-table :data="form.productList" border height="30vh">
  167. <el-table-column label="批次号" align="center" prop="batchNo">
  168. </el-table-column>
  169. <el-table-column label="编码" align="center" prop="productCode">
  170. </el-table-column>
  171. <el-table-column label="名称" align="center" prop="productName">
  172. </el-table-column>
  173. <el-table-column label="规格" align="center" prop="specification">
  174. </el-table-column>
  175. <el-table-column label="牌号" align="center" prop="brandNo">
  176. </el-table-column>
  177. <el-table-column label="数量" align="center" prop="productNumber">
  178. <template slot-scope="scope">
  179. <el-input
  180. v-model="scope.row.productNumber"
  181. :disabled="type == 'detail' || type == 'issued'"
  182. />
  183. </template>
  184. </el-table-column>
  185. <el-table-column
  186. label="工艺路线"
  187. align="center"
  188. prop="produceRoutingId"
  189. >
  190. <template slot-scope="scope">
  191. <el-select
  192. v-model="scope.row.produceRoutingId"
  193. placeholder="请选择"
  194. >
  195. <el-option
  196. style="width: 100%"
  197. v-for="item in routeL"
  198. :key="item.id"
  199. :label="item.name"
  200. :value="item.id"
  201. >
  202. </el-option>
  203. </el-select>
  204. </template>
  205. </el-table-column>
  206. <el-table-column
  207. label="操作"
  208. align="center"
  209. width="70"
  210. v-if="!form.planSourceCode"
  211. >
  212. <template slot-scope="scope">
  213. <el-link
  214. type="danger"
  215. :underline="false"
  216. @click="handleDeleteItem(scope.$index, scope.row.id)"
  217. >
  218. 删除
  219. </el-link>
  220. </template>
  221. </el-table-column>
  222. </el-table>
  223. <div class="add-product" @click="addProduct" v-if="type != 'detail'">
  224. <i class="el-icon-circle-plus-outline"></i>
  225. </div>
  226. <EquipmentDialog
  227. ref="equipmentRefs"
  228. @choose="choose"
  229. :type="1"
  230. :treeIds="['9','1']"
  231. />
  232. <productionPlan ref="productionPlanRef" @choose="choose" />
  233. <workOrder ref="workOrderRef" @choose="choose" />
  234. <produceOrder ref="produceOrderRef" @choose="choose" />
  235. <warehousing ref="warehousingRef" @choose="choose" />
  236. </el-form>
  237. <template v-slot:footer>
  238. <el-button @click="handleClose">取消</el-button>
  239. <el-button
  240. v-if="type != 'detail' && type != 'issued'"
  241. type="primary"
  242. :loading="loading"
  243. @click="save"
  244. >
  245. 保存
  246. </el-button>
  247. <el-button
  248. v-if="type == 'issued'"
  249. type="primary"
  250. :loading="loading"
  251. @click="save"
  252. >
  253. 下发
  254. </el-button>
  255. </template>
  256. </el-dialog>
  257. </template>
  258. <script>
  259. import { save, update, planIssued } from '@/api/inspectionPlan';
  260. import { routeList } from '@/api/aps/index';
  261. import EquipmentDialog from '@/views/inspectionWork/components/EquipmentDialog';
  262. import productionPlan from './productionPlan';
  263. import workOrder from './workOrder';
  264. import produceOrder from './produceOrder';
  265. import warehousing from './warehousing';
  266. import { getUserPage } from '@/api/system/organization';
  267. import deptSelect from '@/components/CommomSelect/dept-select.vue';
  268. // import fileUpload from '@/components/upload/fileUpload';
  269. import fileUpload from '@/components/addDoc/index.vue';
  270. export default {
  271. components: {
  272. EquipmentDialog,
  273. deptSelect,
  274. productionPlan,
  275. workOrder,
  276. produceOrder,
  277. fileUpload,
  278. warehousing
  279. },
  280. data() {
  281. const defaultForm = function () {
  282. return {
  283. id: '',
  284. code: '',
  285. planSourceId: '',
  286. planSourceCode: '',
  287. name: '',
  288. autoOrder: 0,
  289. duration: '',
  290. status: '',
  291. approvalUserId: '',
  292. executeId: '',
  293. groupId: '',
  294. groupName: '',
  295. planStartTime: '',
  296. planEndTime: '',
  297. accessory: [],
  298. // productCode: '',
  299. // productName: '',
  300. // specification: '',
  301. // brandNo: '',
  302. // productNumber: '',
  303. executeName: '',
  304. planSource: '',
  305. batchNo: '',
  306. productList: [],
  307. qualityMode: '',
  308. };
  309. };
  310. return {
  311. defaultForm,
  312. // 表单数据
  313. form: { ...defaultForm() },
  314. sourceList: [],
  315. // 表单验证规则
  316. rules: {
  317. name: [{ required: true, message: '请输入', trigger: 'blur' }]
  318. // productName: [{ required: true, message: '请选择', trigger: 'blur' }]
  319. },
  320. visible: false,
  321. type: null,
  322. title: null,
  323. loading: false,
  324. listPage: [],
  325. executorList: [],
  326. routeL: []
  327. };
  328. },
  329. watch: {
  330. 'form.type'(val) {
  331. this.sourceList =
  332. val == 1
  333. ? [{ label: '采购收货单', value: '1' }]
  334. : val == 2
  335. ? [
  336. { label: '生产计划', value: '2' },
  337. { label: '生产订单', value: '3' },
  338. { label: '生产工单', value: '4' }
  339. ]
  340. : [];
  341. }
  342. },
  343. created() {},
  344. methods: {
  345. open(type, row) {
  346. this.title =
  347. type == 'add'
  348. ? '新增'
  349. : type == 'edit'
  350. ? '编辑'
  351. : type == 'issued'
  352. ? '下发'
  353. : '详情';
  354. this.type = type;
  355. if (this.type != 'add') {
  356. row.accessory = row.accessory || [];
  357. this.form = JSON.parse(JSON.stringify(row));
  358. if (this.form.groupId) {
  359. this.getUserList({ groupId: this.form.groupId });
  360. }
  361. }
  362. this.visible = true;
  363. this.getRouteList();
  364. },
  365. planChange(value) {
  366. this.form.planSource = '';
  367. this.choose({});
  368. },
  369. planSourceChange() {
  370. this.choose({});
  371. if (this.form.planSource) {
  372. this.addProduct();
  373. }
  374. },
  375. handleDeleteItem(index) {
  376. this.form.productList.splice(index, 1);
  377. },
  378. addProduct() {
  379. if (this.form.planSource == 1) {
  380. this.$refs.warehousingRef.open();
  381. } else if (this.form.planSource == 2) {
  382. this.$refs.productionPlanRef.open();
  383. } else if (this.form.planSource == 3) {
  384. this.$refs.workOrderRef.open();
  385. } else if (this.form.planSource == 4) {
  386. this.$refs.produceOrderRef.open();
  387. } else {
  388. this.$refs.equipmentRefs.open();
  389. }
  390. },
  391. /* 保存编辑 */
  392. save() {
  393. this.$refs.form.validate((valid) => {
  394. if (!valid) {
  395. return false;
  396. }
  397. if (this.form.productList.length == 0) {
  398. this.$message.error('请选择产品!');
  399. return;
  400. }
  401. let isBol = this.form.productList.every((e, i) => e.productNumber && e.produceRoutingId)
  402. if(!isBol) {
  403. this.$message.error('请完善数据');
  404. return;
  405. }
  406. this.loading = true;
  407. if (this.type == 'add') {
  408. delete this.form.id;
  409. }
  410. console.log(this.type);
  411. let URL =
  412. this.type == 'add'
  413. ? save
  414. : this.type == 'edit'
  415. ? update
  416. : planIssued;
  417. URL(this.form)
  418. .then((msg) => {
  419. this.loading = false;
  420. this.$message.success(msg);
  421. this.handleClose();
  422. this.$emit('done');
  423. })
  424. .catch((e) => {
  425. this.loading = false;
  426. });
  427. });
  428. },
  429. choose(data) {
  430. if (Array.isArray(data)) {
  431. this.form.productList = [];
  432. data.forEach((item) => {
  433. this.form.productList.push({
  434. productCode: item.code,
  435. productName: item.name,
  436. specification: item.specification,
  437. brandNo: item.brandNum,
  438. productNumber: ''
  439. });
  440. });
  441. return;
  442. }
  443. this.form.productList = data.productList;
  444. this.form.planSourceId = data.id;
  445. this.form.planSourceCode = data.code;
  446. },
  447. //选择部门(搜索)
  448. searchDeptNodeClick(info, row) {
  449. if (info) {
  450. const params = { groupId: info };
  451. this.getUserList(params);
  452. this.form.groupName = row.name;
  453. } else {
  454. this.form.executeGroupId = null;
  455. }
  456. },
  457. // 获取审核人列表、巡点检人员
  458. async getUserList(params) {
  459. try {
  460. let data = { pageNum: 1, size: -1 };
  461. // 如果传了参数就是获取巡点检人员数据
  462. if (params) {
  463. data = Object.assign(data, params);
  464. }
  465. const res = await getUserPage(data);
  466. this.executorList = res.list;
  467. } catch (error) {}
  468. },
  469. // 执行人选择
  470. changeExecutor(val) {
  471. if (val) {
  472. this.form.executeId = val;
  473. this.form.executeName = this.executorList.filter(
  474. (item) => item.id === val
  475. )[0].name;
  476. }
  477. },
  478. restForm() {
  479. this.form = { ...this.defaultForm() };
  480. this.$nextTick(() => {
  481. this.$refs.form.clearValidate();
  482. });
  483. },
  484. handleClose() {
  485. this.restForm();
  486. this.visible = false;
  487. },
  488. getRouteList() {
  489. let params = { pageNum: 1, size: -1, status: 1, routeType: 3 };
  490. routeList(params).then((res) => {
  491. this.routeL = res.list || [];
  492. });
  493. }
  494. }
  495. };
  496. </script>
  497. <style lang="scss" scoped>
  498. .location-warp {
  499. display: flex;
  500. .detail {
  501. margin-left: 10px;
  502. }
  503. }
  504. :deep(.el-form-item__content .el-input-group__prepend) {
  505. background-color: #fff;
  506. }
  507. :deep(
  508. .el-dialog:not(.ele-dialog-form)
  509. .el-dialog__body
  510. .el-form
  511. .el-form-item:last-child
  512. ) {
  513. margin-bottom: 22px;
  514. }
  515. .add-product {
  516. width: 100%;
  517. display: flex;
  518. align-items: center;
  519. justify-content: flex-end;
  520. font-size: 30px;
  521. color: #1890ff;
  522. margin: 10px 0;
  523. cursor: pointer;
  524. }
  525. </style>