user-edit.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356
  1. <!-- 用户编辑弹窗 -->
  2. <template>
  3. <ele-modal width="960px" :visible="visible" :append-to-body="true" :close-on-click-modal="true"
  4. custom-class="ele-dialog-form" :title="isUpdate ? '修改工序' : '添加工序'" @update:visible="updateVisible">
  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 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-row>
  32. <header-title title="工序节拍时间"></header-title>
  33. <el-row>
  34. <el-col :span="12">
  35. <el-form-item label="节拍生产数量" prop="beatProduceNum">
  36. <el-row>
  37. <el-col :span="16">
  38. <el-input placeholder="请输入" v-model.number="form.workBeat.beatProduceNum">
  39. </el-input></el-col>
  40. <el-col :span="1">&nbsp;</el-col>
  41. <el-col :span="7">
  42. <DictSelection dictName="计量单位" v-model="form.workBeat.beatProduceUnit" />
  43. </el-col>
  44. </el-row>
  45. </el-form-item>
  46. </el-col>
  47. <el-col :span="12">
  48. <el-form-item label="对应物料基本数量" label-width="140px" prop="categoryNum">
  49. <el-row>
  50. <el-col :span="16">
  51. <el-input placeholder="请输入" v-model.number="form.workBeat.categoryNum">
  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.categoryUnit" />
  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. </el-form>
  144. <template v-slot:footer>
  145. <el-button @click="updateVisible(false)">取消</el-button>
  146. <el-button type="primary" :loading="loading" @click="save">
  147. 保存
  148. </el-button>
  149. </template>
  150. <!-- 工作中心弹窗 -->
  151. <WorkCenter ref="centerRefs" @changeCenter='determineChoose' />
  152. </ele-modal>
  153. </template>
  154. <script>
  155. import producetask from '@/api/technology/production';
  156. import WorkCenter from './WorkCenter.vue';
  157. export default {
  158. components: {
  159. WorkCenter
  160. },
  161. props: {
  162. // 弹窗是否打开
  163. visible: Boolean,
  164. // 修改回显的数据
  165. data: Object,
  166. controlList: Array
  167. },
  168. data() {
  169. const defaultForm = function () {
  170. return {
  171. id: null,
  172. code: '',
  173. name: '',
  174. controlId: '',
  175. workCenterId: '',
  176. workCenterName: '',
  177. timeUnit: '',
  178. intervalTime: {
  179. nextShortPreTime: '', // 时间单位转换后的下一个短周期的时间,格式为YYYY-MM-DDTHH'
  180. nextStandardPreTime: '', // 时间单位转换后的下一个正式的周期的时间,格式为YYYY-MM-DD'
  181. tactics: 1, // 周期工艺描述,格式为JSON字符串或数组形式的对象形式的数据类
  182. thisShortBoatTime: '',
  183. thisShortPreTime: '',
  184. thisStandardBoatTime: '',
  185. thisStandardWaitTime: ''
  186. },
  187. workBeat: {
  188. beatProduceNum: '',
  189. beatProduceUnit: '',
  190. categoryNum: '',
  191. categoryUnit: '',
  192. beatTimes: '',
  193. otherTimes: '',
  194. preTimes: '',
  195. proTimes: '',
  196. restTimes: '',
  197. beatTimesUnit: ''
  198. }
  199. }
  200. }
  201. return {
  202. defaultForm,
  203. // 表单数据
  204. form: defaultForm(),
  205. timeType: [
  206. { code: 1, label: '分' },
  207. { code: 2, label: '时' }
  208. ],
  209. timeType2: [
  210. { code: '1', label: '分' },
  211. { code: '2', label: '时' }
  212. ],
  213. tacticsType: [
  214. { code: 1, label: '标准时间' },
  215. { code: 2, label: '最短时间' }
  216. ],
  217. // 表单验证规则
  218. rules: {
  219. name: [
  220. { required: true, message: '请输入工序名称', trigger: 'blur' }
  221. ],
  222. code: [{ required: true, trigger: 'change', message: '工序编码', }],
  223. controlId: [
  224. { required: true, message: '请选择控制码', trigger: 'blur' }
  225. ],
  226. workCenterName: [
  227. { required: true, message: '请选择工作中心', trigger: 'change' }
  228. ],
  229. 'workBeat.beatTimesUnit': [
  230. { required: true, message: '请选择时间单位', trigger: 'change' }
  231. ],
  232. timeUnit: [
  233. { required: true, message: '请选择间隔时间单位', trigger: 'change' }
  234. ]
  235. },
  236. // 提交状态
  237. loading: false,
  238. // 是否是修改
  239. isUpdate: false,
  240. chooseItem: null,
  241. };
  242. },
  243. computed: {
  244. totalTime() {
  245. let to =
  246. (-this.form.workBeat.restTimes +
  247. -this.form.workBeat.preTimes +
  248. -this.form.workBeat.proTimes +
  249. -this.form.workBeat.otherTimes) *
  250. -1;
  251. return to;
  252. },
  253. // 是否开启响应式布局
  254. styleResponsive() {
  255. return this.$store.state.theme.styleResponsive;
  256. }
  257. },
  258. methods: {
  259. chooseWorkCenter() {
  260. this.$refs.centerRefs.open(this.form)
  261. },
  262. determineChoose(row) {
  263. this.$set(this.form, 'workCenterName', row.name)
  264. this.$set(this.form, 'workCenterId', row.id)
  265. },
  266. /* 保存编辑 */
  267. save() {
  268. this.$refs.form.validate((valid) => {
  269. if (!valid) {
  270. return false;
  271. }
  272. if (!this.isUpdate) {
  273. delete this.form.id;
  274. }
  275. this.form.workBeat.beatTimes = this.totalTime;
  276. this.loading = true;
  277. producetask
  278. .save(this.form)
  279. .then((msg) => {
  280. this.loading = false;
  281. this.$message.success(
  282. (this.isUpdate ? '修改' : '新建') + msg.message
  283. );
  284. this.updateVisible(false);
  285. this.$emit('done');
  286. })
  287. .catch((e) => {
  288. this.loading = false;
  289. // this.$message.error(e.message);
  290. });
  291. });
  292. },
  293. /* 更新visible */
  294. updateVisible(value) {
  295. this.form = { ...this.defaultForm() };
  296. this.$emit('update:visible', value);
  297. }
  298. },
  299. watch: {
  300. async visible(visible) {
  301. if (visible) {
  302. if (this.data) {
  303. const res = await producetask.getById(this.data.id);
  304. this.$util.assignObject(this.form, {
  305. ...res
  306. });
  307. this.isUpdate = true;
  308. } else {
  309. const res = await producetask.getCode();
  310. this.form = { ...this.defaultForm() };
  311. this.form.code = res;
  312. this.isUpdate = false;
  313. }
  314. } else {
  315. this.$refs.form.clearValidate();
  316. this.form = { ...this.defaultForm() };
  317. }
  318. }
  319. }
  320. };
  321. </script>