user-edit.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521
  1. <!-- 用户编辑弹窗 -->
  2. <template>
  3. <ele-modal width="960px" :visible="visible" :append-to-body="true" :close-on-click-modal="false"
  4. custom-class="ele-dialog-form" :title="isUpdate ? '修改工序' : '添加工序'" @update:visible="updateVisible" :maxable="true">
  5. <header-title title="基本信息"></header-title>
  6. <el-form ref="form" :model="form" :rules="rules" label-width="120px">
  7. <el-row>
  8. <el-col :span="8">
  9. <el-form-item label="工序编码:" prop="code">
  10. <el-input clearable :disabled="isUpdate" v-model="form.code" placeholder="请输入" />
  11. </el-form-item>
  12. </el-col>
  13. <el-col :span="8">
  14. <el-form-item label="工序名称:" prop="name">
  15. <el-input v-model="form.name" clearable placeholder="请输入" />
  16. </el-form-item>
  17. </el-col>
  18. <el-col :span="8">
  19. <el-form-item label="控制码:" prop="controlId">
  20. <el-select v-model="form.controlId" filterable>
  21. <el-option v-for="item in controlList" :key="item.id" :label="item.name" :value="item.id">
  22. </el-option>
  23. </el-select>
  24. </el-form-item>
  25. </el-col>
  26. <el-col :span="8">
  27. <el-form-item label="工作中心:" prop="workCenterName">
  28. <el-input @click.native="chooseWorkCenter" v-model="form.workCenterName" readonly />
  29. </el-form-item>
  30. </el-col>
  31. <el-col :span="8">
  32. <el-form-item label="工序类型:" prop="type">
  33. <el-select v-model="form.type" filterable>
  34. <el-option :label="item.label" :value="item.value" v-for="(item, index) in typeList " :key="index">
  35. </el-option>
  36. </el-select>
  37. </el-form-item>
  38. </el-col>
  39. <el-col :span="8">
  40. <el-form-item label="排序:" prop="sort">
  41. <el-input v-model="form.sort" />
  42. </el-form-item>
  43. </el-col>
  44. </el-row>
  45. <header-title title="工序节拍时间"></header-title>
  46. <el-row>
  47. <el-col :span="12">
  48. <el-form-item label="节拍生产数量" prop="beatProduceNum">
  49. <el-row>
  50. <el-col :span="16">
  51. <el-input placeholder="请输入" v-model.number="form.workBeat.beatProduceNum">
  52. </el-input></el-col>
  53. <el-col :span="1">&nbsp;</el-col>
  54. <el-col :span="7">
  55. <DictSelection dictName="计量单位" v-model="form.workBeat.beatProduceUnit" />
  56. </el-col>
  57. </el-row>
  58. </el-form-item>
  59. </el-col>
  60. <el-col :span="8">
  61. <el-form-item label="工序休息时长:">
  62. <el-input v-model="form.workBeat.restTimes" placeholder="请输入" />
  63. </el-form-item>
  64. </el-col>
  65. <el-col :span="8">
  66. <el-form-item label="工序准备时长:">
  67. <el-input v-model="form.workBeat.preTimes" clearable placeholder="请输入" />
  68. </el-form-item>
  69. </el-col>
  70. <el-col :span="8">
  71. <el-form-item label="设备生产时长:">
  72. <el-input v-model="form.workBeat.proTimes" placeholder="请输入" />
  73. </el-form-item>
  74. </el-col>
  75. <el-col :span="8">
  76. <el-form-item label="其他时长:">
  77. <el-input placeholder="请输入" v-model="form.workBeat.otherTimes" />
  78. </el-form-item>
  79. </el-col>
  80. <el-col :span="8">
  81. <el-form-item label="节拍时间:">
  82. <el-input disabled :value="totalTime"></el-input>
  83. </el-form-item>
  84. </el-col>
  85. <el-col :span="8">
  86. <el-form-item label="节拍时间单位:" prop="workBeat.beatTimesUnit">
  87. <el-select v-model="form.workBeat.beatTimesUnit">
  88. <el-option v-for="item in timeType2" :key="item.code" :label="item.label" :value="item.code">
  89. </el-option>
  90. </el-select>
  91. </el-form-item>
  92. </el-col>
  93. </el-row>
  94. <header-title title="工序间隔时间"></header-title>
  95. <el-row>
  96. <el-col :span="12">
  97. <el-form-item label="间隔策略:" label-width="200px">
  98. <el-select v-model="form.intervalTime.tactics" filterable>
  99. <el-option v-for="item in tacticsType" :key="item.code" :label="item.label" :value="item.code">
  100. </el-option>
  101. </el-select>
  102. </el-form-item>
  103. </el-col>
  104. <el-col :span="8">
  105. <el-form-item label="间隔时间单位:" prop="timeUnit">
  106. <el-select v-model="form.timeUnit">
  107. <el-option v-for="item in timeType" :key="item.code" :label="item.label" :value="item.code">
  108. </el-option>
  109. </el-select>
  110. </el-form-item>
  111. </el-col>
  112. <el-col :span="12">
  113. <el-form-item label="下工序标准准备时间:" label-width="200px">
  114. <el-input v-model="form.intervalTime.nextStandardPreTime" placeholder="请输入" />
  115. </el-form-item>
  116. </el-col>
  117. <el-col :span="12">
  118. <el-form-item label="下工序最短准备时间:" label-width="200px">
  119. <el-input v-model="form.intervalTime.nextShortPreTime" placeholder="请输入" />
  120. </el-form-item>
  121. </el-col>
  122. <el-col :span="12">
  123. <el-form-item label="本工序标准等待时间:" label-width="200px">
  124. <el-input v-model="form.intervalTime.thisStandardWaitTime" placeholder="请输入" />
  125. </el-form-item>
  126. </el-col>
  127. <el-col :span="12">
  128. <el-form-item label="本工序最短准备时间:" label-width="200px">
  129. <el-input v-model="form.intervalTime.thisShortPreTime" placeholder="请输入" />
  130. </el-form-item>
  131. </el-col>
  132. <el-col :span="12">
  133. <el-form-item label="本工序结束后标准周转时间:" label-width="200px">
  134. <el-input v-model="form.intervalTime.thisStandardBoatTime" placeholder="请输入" />
  135. </el-form-item>
  136. </el-col>
  137. <el-col :span="12">
  138. <el-form-item label="本工序结束后周转最短时间:" label-width="200px">
  139. <el-input v-model="form.intervalTime.thisShortBoatTime" placeholder="请输入" />
  140. </el-form-item>
  141. </el-col>
  142. </el-row>
  143. <header-title title="工序配置"></header-title>
  144. <el-row>
  145. <el-col :span="12">
  146. <el-form-item label="投料是否要添加周转车:" label-width="200px">
  147. <el-radio-group v-model="form.feedNeedTurnover">
  148. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  149. </el-radio-group>
  150. </el-form-item>
  151. </el-col>
  152. <el-col :span="12">
  153. <el-form-item label="报工是否要添加周转车:" label-width="200px">
  154. <el-radio-group v-model="form.reportNeedTurnover">
  155. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  156. </el-radio-group>
  157. </el-form-item>
  158. </el-col>
  159. <!-- **** -->
  160. <el-col :span="12">
  161. <el-form-item label="投料是否要添加生产设备:" label-width="200px">
  162. <el-radio-group v-model="form.feedNeedEquipment">
  163. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  164. </el-radio-group>
  165. </el-form-item>
  166. </el-col>
  167. <el-col :span="12">
  168. <el-form-item label="报工是否要添加生产设备:" label-width="200px">
  169. <el-radio-group v-model="form.reportNeedEquipment">
  170. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  171. </el-radio-group>
  172. </el-form-item>
  173. </el-col>
  174. <el-col :span="12">
  175. <el-form-item label="投料是否要添加模具:" label-width="200px">
  176. <el-radio-group v-model="form.feedNeedMould">
  177. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  178. </el-radio-group>
  179. </el-form-item>
  180. </el-col>
  181. <el-col :span="12">
  182. <el-form-item label="投料是否要添加舟皿:" label-width="200px">
  183. <el-radio-group v-model="form.feedNeedBoat">
  184. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  185. </el-radio-group>
  186. </el-form-item>
  187. </el-col>
  188. <el-col :span="12">
  189. <el-form-item label="投料是否要添加消耗材料:" label-width="200px">
  190. <el-radio-group v-model="form.feedNeedConsumableMaterial">
  191. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  192. </el-radio-group>
  193. </el-form-item>
  194. </el-col>
  195. <el-col :span="12">
  196. <el-form-item label="投料是否要添加物料:" label-width="200px">
  197. <el-radio-group v-model="form.feedNeedMateriel">
  198. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  199. </el-radio-group>
  200. </el-form-item>
  201. </el-col>
  202. <el-col :span="12">
  203. <el-form-item label="投料是否要添加产品:" label-width="200px">
  204. <el-radio-group v-model="form.feedNeedProduct">
  205. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  206. </el-radio-group>
  207. </el-form-item>
  208. </el-col>
  209. <el-col :span="12">
  210. <el-form-item label="投料是否要添加半成品:" label-width="200px">
  211. <el-radio-group v-model="form.feedNeedSemiProduct">
  212. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  213. </el-radio-group>
  214. </el-form-item>
  215. </el-col>
  216. <el-col :span="12">
  217. <el-form-item label="投料是否要添加废品:" label-width="200px">
  218. <el-radio-group v-model="form.feedNeedJunkProduct">
  219. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  220. </el-radio-group>
  221. </el-form-item>
  222. </el-col>
  223. <el-col :span="12">
  224. <el-form-item label="投料是否要添加返工反修品:" label-width="200px">
  225. <el-radio-group v-model="form.feedNeedReworkProduct">
  226. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  227. </el-radio-group>
  228. </el-form-item>
  229. </el-col>
  230. <el-col :span="12">
  231. <el-form-item label="投料是否要添加干燥区:" label-width="200px">
  232. <el-radio-group v-model="form.feedNeedAridRegion">
  233. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  234. </el-radio-group>
  235. </el-form-item>
  236. </el-col>
  237. <el-col :span="12">
  238. <el-form-item label="投料是否要添加生产辅助设备:" label-width="200px">
  239. <el-radio-group v-model="form.feedNeedAuxiliaryEquipment">
  240. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  241. </el-radio-group>
  242. </el-form-item>
  243. </el-col>
  244. <el-col :span="12">
  245. <el-form-item label="投料是否要添加仪表计量设备:" label-width="200px">
  246. <el-radio-group v-model="form.feedNeedMeasuringEquipment">
  247. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  248. </el-radio-group>
  249. </el-form-item>
  250. </el-col>
  251. <el-col :span="12">
  252. <el-form-item label="投料是否需要质检:" label-width="200px">
  253. <el-radio-group v-model="form.feedNeedQuality">
  254. <el-radio :label="item.value" v-for="(item,i) in radioList" :key="i">{{ item.name }}</el-radio>
  255. </el-radio-group>
  256. </el-form-item>
  257. </el-col>
  258. </el-row>
  259. </el-form>
  260. <template v-slot:footer>
  261. <el-button @click="updateVisible(false)">取消</el-button>
  262. <el-button type="primary" :loading="loading" @click="save">
  263. 保存
  264. </el-button>
  265. </template>
  266. <!-- 工作中心弹窗 -->
  267. <WorkCenter ref="centerRefs" @changeCenter='determineChoose' />
  268. </ele-modal>
  269. </template>
  270. <script>
  271. import producetask from '@/api/technology/production';
  272. import WorkCenter from './WorkCenter.vue';
  273. export default {
  274. components: {
  275. WorkCenter
  276. },
  277. props: {
  278. // 弹窗是否打开
  279. visible: Boolean,
  280. // 修改回显的数据
  281. data: Object,
  282. controlList: Array,
  283. typeList: Array
  284. },
  285. data() {
  286. const defaultForm = function () {
  287. return {
  288. id: null,
  289. code: '',
  290. name: '',
  291. controlId: '',
  292. type: 1,
  293. workCenterId: '',
  294. workCenterName: '',
  295. timeUnit: '',
  296. feedNeedTurnover:'',
  297. reportNeedTurnover:'',
  298. feedNeedEquipment:'',
  299. reportNeedEquipment:'',
  300. feedNeedMould:'',
  301. feedNeedBoat:'',
  302. feedNeedConsumableMaterial:'',
  303. feedNeedMateriel:'',
  304. feedNeedProduct:'',
  305. feedNeedSemiProduct:'',
  306. feedNeedJunkProduct:'',
  307. feedNeedReworkProduct:'',
  308. feedNeedAridRegion:'',
  309. feedNeedAuxiliaryEquipment:'',
  310. feedNeedMeasuringEquipment:'',
  311. feedNeedQuality:'',
  312. sort: null,
  313. intervalTime: {
  314. nextShortPreTime: '', // 时间单位转换后的下一个短周期的时间,格式为YYYY-MM-DDTHH'
  315. nextStandardPreTime: '', // 时间单位转换后的下一个正式的周期的时间,格式为YYYY-MM-DD'
  316. tactics: 1, // 周期工艺描述,格式为JSON字符串或数组形式的对象形式的数据类
  317. thisShortBoatTime: '',
  318. thisShortPreTime: '',
  319. thisStandardBoatTime: '',
  320. thisStandardWaitTime: ''
  321. },
  322. workBeat: {
  323. beatProduceNum: '',
  324. beatProduceUnit: '',
  325. categoryNum: '',
  326. categoryUnit: '',
  327. beatTimes: '',
  328. otherTimes: '',
  329. preTimes: '',
  330. proTimes: '',
  331. restTimes: '',
  332. beatTimesUnit: ''
  333. }
  334. }
  335. }
  336. return {
  337. defaultForm,
  338. // 表单数据
  339. form: defaultForm(),
  340. timeType: [
  341. { code: 1, label: '分' },
  342. { code: 2, label: '时' }
  343. ],
  344. radioList:[
  345. {
  346. name:'是',
  347. value:1
  348. },
  349. {
  350. name:'否',
  351. value:0
  352. }
  353. ],
  354. timeType2: [
  355. { code: '1', label: '分' },
  356. { code: '2', label: '时' }
  357. ],
  358. tacticsType: [
  359. { code: 1, label: '标准时间' },
  360. { code: 2, label: '最短时间' }
  361. ],
  362. // 表单验证规则
  363. rules: {
  364. name: [
  365. { required: true, message: '请输入工序名称', trigger: 'blur' }
  366. ],
  367. code: [{ required: true, trigger: 'change', message: '工序编码', }],
  368. controlId: [
  369. { required: true, message: '请选择控制码', trigger: 'blur' }
  370. ],
  371. workCenterName: [
  372. { required: true, message: '请选择工作中心', trigger: 'change' }
  373. ],
  374. 'workBeat.beatTimesUnit': [
  375. { required: true, message: '请选择时间单位', trigger: 'change' }
  376. ],
  377. timeUnit: [
  378. { required: true, message: '请选择间隔时间单位', trigger: 'change' }
  379. ]
  380. },
  381. // 提交状态
  382. loading: false,
  383. // 是否是修改
  384. isUpdate: false,
  385. chooseItem: null,
  386. };
  387. },
  388. computed: {
  389. totalTime() {
  390. let to =
  391. (-this.form.workBeat.restTimes +
  392. -this.form.workBeat.preTimes +
  393. -this.form.workBeat.proTimes +
  394. -this.form.workBeat.otherTimes) *
  395. -1;
  396. return to;
  397. },
  398. // 是否开启响应式布局
  399. styleResponsive() {
  400. return this.$store.state.theme.styleResponsive;
  401. }
  402. },
  403. methods: {
  404. chooseWorkCenter() {
  405. this.$refs.centerRefs.open(this.form)
  406. },
  407. determineChoose(row) {
  408. this.$set(this.form, 'workCenterName', row.name)
  409. this.$set(this.form, 'workCenterId', row.id)
  410. },
  411. /* 保存编辑 */
  412. save() {
  413. this.$refs.form.validate((valid) => {
  414. if (!valid) {
  415. return false;
  416. }
  417. if (!this.isUpdate) {
  418. delete this.form.id;
  419. }
  420. this.form.workBeat.beatTimes = this.totalTime;
  421. this.loading = true;
  422. producetask
  423. .save(this.form)
  424. .then((msg) => {
  425. this.loading = false;
  426. this.$message.success(
  427. (this.isUpdate ? '修改' : '新建') + msg.message
  428. );
  429. this.updateVisible(false);
  430. this.$emit('done');
  431. })
  432. .catch((e) => {
  433. this.loading = false;
  434. // this.$message.error(e.message);
  435. });
  436. });
  437. },
  438. /* 更新visible */
  439. updateVisible(value) {
  440. this.form = { ...this.defaultForm() };
  441. this.$emit('update:visible', value);
  442. }
  443. },
  444. watch: {
  445. async visible(visible) {
  446. if (visible) {
  447. console.log(this.form,'this.form');
  448. if (this.data) {
  449. const res = await producetask.getById(this.data.id);
  450. this.$util.assignObject(this.form, {
  451. ...res
  452. });
  453. this.isUpdate = true;
  454. } else {
  455. this.form = { ...this.defaultForm() };
  456. this.isUpdate = false;
  457. }
  458. } else {
  459. this.$refs.form.clearValidate();
  460. this.form = { ...this.defaultForm() };
  461. }
  462. }
  463. }
  464. };
  465. </script>