MaterialModal.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496
  1. <template>
  2. <ele-modal width="1260px" :visible="visible" v-if="visible" :append-to-body="true" :close-on-click-modal="true"
  3. custom-class="ele-dialog-form" title="选择物料" @update:visible="updateVisible">
  4. <header-title title="基本信息"></header-title>
  5. <el-form ref="form" :model="form" :rules="rules" label-width="120px">
  6. <el-row>
  7. <el-col :span="8">
  8. <el-form-item label="产品名称:" prop="name">
  9. <el-input disabled v-model="form.name" readonly />
  10. </el-form-item>
  11. </el-col>
  12. <el-col :span="8">
  13. <el-form-item label="产品编码:" prop="code">
  14. <el-input disabled v-model="form.code" placeholder="自动带入" />
  15. </el-form-item>
  16. </el-col>
  17. <el-col :span="8">
  18. <el-form-item label="型号:" prop="modelType">
  19. <el-input disabled v-model="form.modelType" placeholder="自动带入" />
  20. </el-form-item>
  21. </el-col>
  22. <el-col :span="8">
  23. <el-form-item label="牌号:" prop="brandNum">
  24. <el-input disabled v-model="form.brandNum" placeholder="自动带入" />
  25. </el-form-item>
  26. </el-col>
  27. <el-col :span="8">
  28. <el-form-item label="规格:" prop="specification">
  29. <el-input disabled v-model="form.specification" placeholder="自动带入" />
  30. </el-form-item>
  31. </el-col>
  32. <el-col :span="8">
  33. <el-form-item label="计量单位:" prop="measuringUnit">
  34. <el-input disabled v-model="form.measuringUnit" placeholder="自动带入" />
  35. </el-form-item>
  36. </el-col>
  37. </el-row>
  38. <el-button type="primary" size="small" style="margin-bottom: 10px;" @click="handleAddTab">添加工序</el-button>
  39. <el-tabs v-model="tabsValue" type="card" closable @tab-click="handleTab" @tab-remove="removeTab">
  40. <el-tab-pane v-for="(item, index) in tabsList" :key="item.id + index" :label="item.name" :name="item.id">
  41. <header-title title="物料BOM" style="margin-top: 10px">
  42. <div>
  43. <el-button size="small" icon="el-icon-plus" class="ele-btn-icon" type="primary"
  44. @click="handleAdd(item.id)">新增</el-button>
  45. </div>
  46. </header-title>
  47. <el-card v-for="(bomItem, index) in form.bomList" :key="index">
  48. <el-row>
  49. <el-col :span="8">
  50. <el-form-item label="BOM编码:">
  51. {{ bomItem.code }}
  52. </el-form-item>
  53. </el-col>
  54. <el-col :span="8">
  55. <el-form-item label="BOM名称:" prop="name">
  56. {{ bomItem.name }}
  57. </el-form-item>
  58. </el-col>
  59. <el-col :span="8">
  60. <el-form-item label="版本号:" prop="version">
  61. {{ bomItem.version }}
  62. </el-form-item>
  63. </el-col>
  64. <el-col :span="8">
  65. <el-form-item label="状态:" prop="status">
  66. <el-select v-model="bomItem.status" placeholder="" filterable disabled>
  67. <el-option v-for="item in statusList" :key="item.value" :label="item.label"
  68. :value="item.value">
  69. </el-option>
  70. </el-select>
  71. </el-form-item>
  72. </el-col>
  73. <el-col :span="8">
  74. <el-form-item label="所属工厂:" prop="factoryId">
  75. <factorySelect v-model="bomItem.factoryId" disabled />
  76. </el-form-item>
  77. </el-col>
  78. <el-col :span="8">
  79. <el-form-item label="基本数量:" prop="baseCount">
  80. <el-row>
  81. <el-col :span="12">
  82. {{ bomItem.baseCount }}
  83. </el-col>
  84. <el-col :span="2">&nbsp;</el-col>
  85. <el-col :span="10">
  86. <DictSelection disabled dictName="计量单位:" v-model="bomItem.baseCountUnit" />
  87. </el-col>
  88. </el-row>
  89. </el-form-item>
  90. </el-col>
  91. </el-row>
  92. <el-row>
  93. <div class="ele-body">
  94. <ele-pro-table ref="table" :columns="columns" :need-page="false" row-key="id"
  95. :datasource="bomItem.subDetailList" min-height="200px">
  96. <template v-slot:isReworkBom="{ row }">
  97. {{ row.isReworkBom ? '是' : '否' }}
  98. </template>
  99. <template v-slot:toolbar>
  100. <el-button type="primary" size="small" @click="openEdit(index)">编辑</el-button>
  101. <el-popconfirm class="ele-action" title="确定要删除此物料BOM?" @confirm="remove(bomItem)">
  102. <template v-slot:reference>
  103. <el-button type="danger" size="small" icon="el-icon-delete">
  104. 删除
  105. </el-button>
  106. </template>
  107. </el-popconfirm>
  108. </template>
  109. </ele-pro-table>
  110. </div>
  111. </el-row>
  112. </el-card>
  113. </el-tab-pane>
  114. </el-tabs>
  115. </el-form>
  116. <!-- 物料Bom -->
  117. <MaterialAdd :visible.sync="materialShow" :taskId="taskId" :data="current" :categoryId="categoryId" @done="done"
  118. ref="materialAddRef">
  119. </MaterialAdd>
  120. <!-- 添加工序 -->
  121. <ele-modal width="1720px" :visible="addDialog" :append-to-body="true" :close-on-click-modal="true"
  122. @update:visible="closeAdd">
  123. <Production :tableData="tableData" ref="ProductionCom" />
  124. <template v-slot:footer>
  125. <el-button @click="closeAdd">取消</el-button>
  126. <el-button type="primary" @click="addParamrter">
  127. 添加
  128. </el-button>
  129. </template>
  130. </ele-modal>
  131. </ele-modal>
  132. </template>
  133. <script>
  134. import MaterialAdd from './MaterialAdd.vue';
  135. import { pageList } from '@/api/technology/version/version.js';
  136. import { getCategoryBom } from '@/api/material/product';
  137. import { bomDelete, saveBatch, bomTaskList, bomTaskDelete, getByTaskId } from '@/api/material/BOM';
  138. import factorySelect from '@/components/CommomSelect/factory-select.vue';
  139. import Production from '@/views/technology/route/components/production/index.vue'
  140. export default {
  141. components: {
  142. MaterialAdd,
  143. factorySelect,
  144. Production
  145. },
  146. props: {
  147. // 弹窗是否打开
  148. visible: Boolean,
  149. // 修改回显的数据
  150. data: Object
  151. },
  152. data() {
  153. const defaultForm = {
  154. id: null,
  155. code: '',
  156. name: '',
  157. modelType: '',
  158. brandNum: '',
  159. specification: '',
  160. measuringUnit: '',
  161. bomList: []
  162. };
  163. return {
  164. defaultForm,
  165. // 表单数据
  166. form: {
  167. ...defaultForm
  168. },
  169. versionList: [],
  170. // 表单验证规则
  171. rules: {
  172. categoryName: [
  173. { required: true, message: '请输入产品名称', trigger: 'blur' }
  174. ]
  175. },
  176. columns: [
  177. {
  178. type: 'index',
  179. width: 55,
  180. align: 'center'
  181. },
  182. {
  183. label: '子项编号',
  184. prop: 'subCode',
  185. action: 'subCode'
  186. },
  187. {
  188. label: '物料名称',
  189. prop: 'categoryName',
  190. action: 'categoryName'
  191. },
  192. {
  193. label: '是否反工料',
  194. prop: 'isReworkBom',
  195. action: 'isReworkBom',
  196. slot: 'isReworkBom',
  197. width: 95,
  198. },
  199. {
  200. label: '物料编码',
  201. prop: 'categoryCode'
  202. },
  203. {
  204. label: '牌号',
  205. prop: 'brandNum'
  206. },
  207. {
  208. label: '型号',
  209. prop: 'modelType'
  210. },
  211. {
  212. label: '数量',
  213. prop: 'count'
  214. },
  215. {
  216. label: '计量单位',
  217. prop: 'unit'
  218. },
  219. {
  220. label: '数量',
  221. prop: 'netWeight'
  222. },
  223. {
  224. label: '单位',
  225. prop: 'weightUnit'
  226. },
  227. ],
  228. statusList: [
  229. { label: '草稿', value: -1 },
  230. { label: '失效', value: 0 },
  231. { label: '生效', value: 1 }
  232. ],
  233. // 提交状态
  234. loading: false,
  235. categoryId: null,
  236. current: null,
  237. materialShow: false,
  238. tabsList: [],
  239. tableData: [],
  240. taskId: null,
  241. addDialog: false,
  242. tabsValue: null
  243. };
  244. },
  245. computed: {
  246. // 是否开启响应式布局
  247. styleResponsive() {
  248. return this.$store.state.theme.styleResponsive;
  249. }
  250. },
  251. methods: {
  252. openEdit(index) {
  253. this.current = this.form.bomList[index];
  254. console.log(this.current);
  255. this.materialShow = true;
  256. },
  257. /* 表格数据源 */
  258. datasource({ page, limit, where }) {
  259. return [];
  260. },
  261. async getVersionList() {
  262. const res = await pageList({
  263. pageNum: 1,
  264. size: 100
  265. });
  266. this.versionList = res.list;
  267. },
  268. handleAdd(id) {
  269. this.taskId = id
  270. this.current = null;
  271. this.materialShow = true;
  272. },
  273. /* 更新visible */
  274. updateVisible(value) {
  275. this.$emit('update:visible', value);
  276. },
  277. async getCategoryBomFn(taskId) {
  278. const res = await getByTaskId(this.categoryId, taskId);
  279. this.form.bomList = res;
  280. },
  281. remove(row) {
  282. bomDelete([row.id])
  283. .then((message) => {
  284. this.$message.success(message);
  285. this.getCategoryBomFn();
  286. })
  287. .catch((e) => {
  288. this.$message.error(e.message);
  289. });
  290. },
  291. done(taskId) {
  292. this.materialShow = false
  293. this.getCategoryBomFn(taskId);
  294. },
  295. handleAddTab() {
  296. this.tableData = this.tabsList
  297. this.addDialog = true;
  298. },
  299. handleTab(e) {
  300. this.getCategoryBomFn(e.name);
  301. },
  302. removeTab(targetName) {
  303. this.$confirm('是否删除当前工序?', '提示', {
  304. confirmButtonText: '确定',
  305. cancelButtonText: '取消',
  306. type: 'warning'
  307. })
  308. .then(() => {
  309. this.tabsList.forEach(e => {
  310. if (e.id == targetName) {
  311. bomTaskDelete([e.oldId]).then(res => {
  312. this.taskListHead()
  313. })
  314. }
  315. })
  316. })
  317. .catch(() => { });
  318. },
  319. /*关闭选择参数*/
  320. closeAdd() {
  321. this.$refs.ProductionCom.$refs.table.setSelectedRows([]);
  322. this.addDialog = false;
  323. },
  324. addParamrter() {
  325. let arr = [];
  326. arr = this.$refs.ProductionCom.selection.map(m => {
  327. return {
  328. sourceTaskId: m.id,
  329. ...m
  330. }
  331. })
  332. if (arr.length == 0) {
  333. this.addDialog = false;
  334. return false
  335. }
  336. this.tabsList = arr
  337. this.addDialog = false;
  338. this.$refs.ProductionCom.$refs.table.setSelectedRows([]);
  339. if (this.tabsList.length > 0) {
  340. this.tabsValue = this.tabsList[0].id
  341. this.saveBatchFn()
  342. }
  343. },
  344. // 保存
  345. saveBatchFn() {
  346. let arr = [];
  347. arr = this.tabsList.map(m => {
  348. return {
  349. taskId: m.id,
  350. sort: m.sort,
  351. categoryId: this.categoryId
  352. }
  353. })
  354. saveBatch(arr).then(res => {
  355. this.taskListHead()
  356. })
  357. },
  358. taskListHead(isFirst) {
  359. console.log(isFirst)
  360. bomTaskList(this.categoryId).then(res => {
  361. let arr = []
  362. arr = res.map(m => {
  363. return {
  364. oldId: m.id,
  365. sourceTaskId: m.id,
  366. id: m.taskId,
  367. name: m.taskName
  368. }
  369. })
  370. this.tabsList = arr
  371. if (isFirst && this.tabsList.length > 0) {
  372. this.tabsValue = this.tabsList[0].id
  373. this.getCategoryBomFn(this.tabsList[0].id);
  374. }
  375. })
  376. },
  377. },
  378. watch: {
  379. async visible(visible) {
  380. if (visible) {
  381. this.getVersionList();
  382. if (this.data) {
  383. this.categoryId = this.data.id;
  384. this.$util.assignObject(this.form, {
  385. ...this.data
  386. });
  387. } else {
  388. }
  389. this.taskListHead(true)
  390. } else {
  391. this.$refs.form.clearValidate();
  392. this.form = { ...this.defaultForm };
  393. }
  394. }
  395. }
  396. };
  397. </script>
  398. <style lang="scss" scoped></style>