index.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524
  1. <template>
  2. <div class="ele-body">
  3. <el-card shadow="never">
  4. <!-- 搜索表单 -->
  5. <!-- <user-search @search="reload" /> -->
  6. <seek-page :seekList="seekList" @search="reload"></seek-page>
  7. <!-- 数据表格 -->
  8. <ele-pro-table
  9. ref="table"
  10. :columns="columns"
  11. :datasource="datasource"
  12. :selection.sync="selection"
  13. row-key="id"
  14. :pageSize="this.$store.state.tablePageSize"
  15. @columns-change="handleColumnChange"
  16. :cache-key="cacheKeyUrl"
  17. >
  18. <!-- 表头工具栏 -->
  19. <template v-slot:toolbar>
  20. <el-button
  21. size="small"
  22. type="primary"
  23. icon="el-icon-plus"
  24. class="ele-btn-icon"
  25. @click="openEdit()"
  26. v-if="$hasPermission('main:producetask:save')"
  27. >
  28. 新建
  29. </el-button>
  30. <el-button
  31. size="small"
  32. type="danger"
  33. icon="el-icon-delete"
  34. class="ele-btn-icon"
  35. @click="removeBatch"
  36. v-if="$hasPermission('main:producetask:delete')"
  37. >
  38. 删除
  39. </el-button>
  40. <el-button
  41. size="small"
  42. type="primary"
  43. icon="el-icon-download"
  44. class="ele-btn-icon"
  45. plain
  46. v-if="$hasPermission('main:producetask:update')"
  47. @click="uploadFile()"
  48. >
  49. 导入
  50. </el-button>
  51. <el-button
  52. size="small"
  53. type="primary"
  54. class="ele-btn-icon"
  55. @click="batchUpdateWorkCenter()"
  56. >
  57. 批量修改工作中心
  58. </el-button>
  59. </template>
  60. <template v-slot:name="{ row }">
  61. <!-- <el-link v-if="row.type == 2" type="primary" :underline="false" @click="sampleParam(row)">
  62. {{ row.name }}
  63. </el-link>
  64. <span v-else> {{ row.name }}</span> -->
  65. {{ row.name }}
  66. </template>
  67. <!-- 状态列 -->
  68. <template v-slot:type="{ row }">
  69. {{ typeLabel(row.type) }}
  70. </template>
  71. <!-- 操作列 -->
  72. <template v-slot:action="{ row }">
  73. <el-link
  74. type="primary"
  75. :underline="false"
  76. icon="el-icon-edit"
  77. @click="openEdit(row)"
  78. v-if="$hasPermission('main:producetask:update')"
  79. >
  80. 修改
  81. </el-link>
  82. <!-- <el-link
  83. type="primary"
  84. :underline="false"
  85. icon="el-icon-setting"
  86. @click="openSetting(row)"
  87. >
  88. 配置工艺参数
  89. </el-link> -->
  90. <el-popconfirm
  91. class="ele-action"
  92. title="确定要删除当前工序吗?"
  93. @confirm="remove(row)"
  94. v-if="$hasPermission('main:producetask:delete')"
  95. >
  96. <template v-slot:reference>
  97. <el-link type="danger" :underline="false" icon="el-icon-delete">
  98. 删除
  99. </el-link>
  100. </template>
  101. </el-popconfirm>
  102. <el-link
  103. type="primary"
  104. :underline="false"
  105. icon="el-icon-setting"
  106. @click="openSettingMatter(row)"
  107. >
  108. 配置事项
  109. </el-link>
  110. </template>
  111. </ele-pro-table>
  112. </el-card>
  113. <!-- 编辑弹窗 -->
  114. <user-edit
  115. :visible.sync="showEdit"
  116. :data="current"
  117. :controlList="controlList"
  118. @done="reload"
  119. ref="userEdit"
  120. :typeList="typeList"
  121. />
  122. <!-- 配置工艺参数 -->
  123. <user-setting
  124. :visible.sync="showSetting"
  125. :data="current"
  126. ref="userSetting"
  127. />
  128. <SampleParam
  129. v-if="sampleShow"
  130. :taskId="taskId"
  131. @close="close"
  132. ></SampleParam>
  133. <importDialog
  134. fileName="工艺_工序导入模板"
  135. apiUrl="/main/producetask/importExcel"
  136. fileUrl="/main/producetask/downLoadTemplate"
  137. ref="importDialogRef"
  138. @success="reload"
  139. />
  140. <!-- 配置事项 -->
  141. <userSettingMatter ref="userSettingMatterRef" />
  142. <WorkCenter ref="centerRefs" @changeCenter="determineChoose" />
  143. </div>
  144. </template>
  145. <script>
  146. import tabMixins from '@/mixins/tableColumnsMixin';
  147. import UserSearch from './components/user-search.vue';
  148. import UserEdit from './components/user-edit.vue';
  149. import UserSetting from './components/user-setting.vue';
  150. import SampleParam from './components/sampleParam.vue';
  151. import producetask from '@/api/technology/production';
  152. import control from '@/api/technology/control';
  153. import importDialog from '@/components/upload/comm-dialog.vue';
  154. import work from '@/api/technology/work';
  155. import WorkCenter from './components/WorkCenter.vue';
  156. import userSettingMatter from './components/user-setting-matter.vue';
  157. import dictMixins from '@/mixins/dictMixins';
  158. export default {
  159. name: 'technologyProduction',
  160. mixins: [tabMixins, dictMixins],
  161. components: {
  162. UserSearch,
  163. UserEdit,
  164. UserSetting,
  165. SampleParam,
  166. importDialog,
  167. WorkCenter,
  168. userSettingMatter
  169. },
  170. data() {
  171. return {
  172. moudleName: 'mainProduceTask',
  173. // 表格列配置
  174. columns: [
  175. {
  176. columnKey: 'selection',
  177. type: 'selection',
  178. width: 45,
  179. align: 'center',
  180. fixed: 'left'
  181. },
  182. {
  183. prop: 'sort',
  184. label: '排序',
  185. align: 'center'
  186. },
  187. {
  188. prop: 'code',
  189. label: '工序编码',
  190. // sortable: 'custom',
  191. showOverflowTooltip: true,
  192. align: 'center',
  193. minWidth: 110
  194. },
  195. {
  196. slot: 'name',
  197. label: '工序名称',
  198. showOverflowTooltip: true,
  199. align: 'center',
  200. minWidth: 110
  201. },
  202. {
  203. slot: 'type',
  204. label: '工序类型',
  205. showOverflowTooltip: true,
  206. align: 'center',
  207. minWidth: 110
  208. },
  209. {
  210. align: 'center',
  211. prop: 'controlName',
  212. label: '工序控制码',
  213. showOverflowTooltip: true,
  214. minWidth: 110
  215. },
  216. {
  217. prop: 'workCenterName',
  218. label: '所属工作中心',
  219. align: 'center',
  220. showOverflowTooltip: true,
  221. minWidth: 110
  222. },
  223. {
  224. prop: 'factoriesName',
  225. label: '所属工厂',
  226. align: 'center',
  227. showOverflowTooltip: true,
  228. minWidth: 110
  229. },
  230. {
  231. columnKey: 'action',
  232. label: '操作',
  233. width: 260,
  234. align: 'center',
  235. resizable: false,
  236. slot: 'action',
  237. showOverflowTooltip: true
  238. }
  239. ],
  240. // 表格选中数据
  241. selection: [],
  242. // 当前编辑数据
  243. current: null,
  244. // 是否显示编辑弹窗
  245. showEdit: false,
  246. // 是否显示参数弹窗
  247. showSetting: false,
  248. controlList: [],
  249. typeList: [
  250. {
  251. value: 99,
  252. label: '关键工序'
  253. },
  254. {
  255. value: 1,
  256. label: '普通工序'
  257. },
  258. // {
  259. // value: 2,
  260. // label: '抽样质检'
  261. // },
  262. {
  263. value: 3,
  264. label: '抽样质检'
  265. },
  266. {
  267. value: 4,
  268. label: '包装工序'
  269. },
  270. {
  271. value: 6,
  272. label: '质检工序'
  273. },
  274. {
  275. value: 7,
  276. label: '生产准备'
  277. }
  278. ],
  279. sampleShow: false,
  280. taskId: null,
  281. cacheKeyUrl: 'abfad404-technology-production',
  282. controlListNewList: [], //给公共组件使用
  283. workCenterList: [] //工作中心列表
  284. };
  285. },
  286. computed: {
  287. seekList() {
  288. return [
  289. {
  290. label: '工序编码:',
  291. value: 'code',
  292. type: 'input',
  293. placeholder: ''
  294. },
  295. {
  296. label: '工序名称:',
  297. value: 'name',
  298. type: 'input',
  299. placeholder: ''
  300. },
  301. {
  302. label: '控制码:',
  303. value: 'controlId',
  304. type: 'select',
  305. placeholder: '',
  306. planList: this.controlListNewList
  307. },
  308. {
  309. label: '工序类型:',
  310. value: 'type',
  311. type: 'select',
  312. placeholder: '',
  313. planList: this.typeList
  314. },
  315. {
  316. label: '工作中心:',
  317. value: 'workCenterId',
  318. type: 'select',
  319. placeholder: '',
  320. planList: this.workCenterList
  321. }
  322. ];
  323. }
  324. },
  325. created() {
  326. this.getControlList();
  327. this.getListWorkCenter();
  328. this.requestDict('记录规则报工类型');
  329. this.requestDict('记录规则执行方式');
  330. this.requestDict('记录规则事项类型');
  331. },
  332. methods: {
  333. openSettingMatter(row) {
  334. this.$refs.userSettingMatterRef.openSetting(row);
  335. },
  336. typeLabel(type) {
  337. return (
  338. this.typeList.find((m) => m.value == type) &&
  339. this.typeList.find((m) => m.value == type).label
  340. );
  341. },
  342. /*配置工艺参数 */
  343. openSetting(row) {
  344. this.current = row;
  345. this.showSetting = true;
  346. },
  347. /* 表格数据源 */
  348. async datasource({ page, limit, where, order }) {
  349. const res = await producetask.list({
  350. ...where,
  351. ...order,
  352. pageNum: page,
  353. size: limit
  354. });
  355. return res;
  356. },
  357. batchUpdateWorkCenter() {
  358. if (!this.selection.length) {
  359. this.$message.error('请至少选择一条数据');
  360. return;
  361. }
  362. this.$refs.centerRefs.open(this.selection[0]);
  363. },
  364. /* 刷新表格 */
  365. reload(where) {
  366. this.$refs.table.reload({ page: 1, where: where });
  367. },
  368. /* 打开编辑弹窗 */
  369. openEdit(row) {
  370. this.getControlList();
  371. this.current = row;
  372. this.showEdit = true;
  373. this.$refs.userEdit.$refs.form &&
  374. this.$refs.userEdit.$refs.form.clearValidate();
  375. },
  376. determineChoose(row) {
  377. if (row) {
  378. this.loading = true;
  379. this.selection.forEach((item) => {
  380. item.workCenterName = row.name;
  381. item.workCenterId = row.id;
  382. });
  383. producetask
  384. .bacthUpdate(JSON.parse(JSON.stringify(this.selection)))
  385. .then((res) => {
  386. if (res.code == 0) {
  387. this.$message.success('修改成功');
  388. }
  389. this.loading = false;
  390. })
  391. .catch((e) => {
  392. this.loading = false;
  393. });
  394. }
  395. // this.loading = true;
  396. // for (let i = 0; i < this.selection.length; i++) {
  397. // this.selection[i].workCenterName = row.name;
  398. // this.selection[i].workCenterId = row.id;
  399. // producetask
  400. // .save(this.selection[i])
  401. // .then((msg) => {
  402. // if (this.selection.length == i) {
  403. // this.loading = false;
  404. // this.$message.success('修改成功');
  405. // }
  406. // })
  407. // .catch((e) => {
  408. // this.loading = false;
  409. // return;
  410. // });
  411. // }
  412. },
  413. getControlList() {
  414. const params = {
  415. pageNum: 1,
  416. size: -1
  417. };
  418. control.list().then((res) => {
  419. this.controlList = res.list;
  420. this.controlListNewList = res.list.map((m) => ({
  421. label: m.name,
  422. value: m.id
  423. }));
  424. });
  425. },
  426. /* 删除 */
  427. remove(row) {
  428. const loading = this.$loading({ lock: true });
  429. producetask
  430. .delete([row.id])
  431. .then((msg) => {
  432. loading.close();
  433. // this.$message.success('删除成功');
  434. this.reload();
  435. })
  436. .catch((e) => {
  437. loading.close();
  438. // this.$message.error(e.message);
  439. });
  440. },
  441. /* 批量删除 */
  442. removeBatch() {
  443. if (!this.selection.length) {
  444. this.$message.error('请至少选择一条数据');
  445. return;
  446. }
  447. this.$confirm('确定要删除选中的工序吗?', '提示', {
  448. type: 'warning'
  449. })
  450. .then(() => {
  451. const loading = this.$loading({ lock: true });
  452. producetask
  453. .delete(this.selection.map((d) => d.id))
  454. .then((msg) => {
  455. // if(code=='0'){
  456. // this.$message.success('删除成功');
  457. // }else{
  458. // this.$message.error(msg.message);
  459. // }
  460. loading.close();
  461. this.reload();
  462. })
  463. .catch((e) => {
  464. loading.close();
  465. // this.$message.error(e.message);
  466. });
  467. })
  468. .catch(() => {});
  469. },
  470. sampleParam(row) {
  471. this.taskId = row.id;
  472. this.sampleShow = true;
  473. },
  474. close(done) {
  475. this.sampleShow = false;
  476. },
  477. uploadFile() {
  478. this.$refs.importDialogRef.open();
  479. },
  480. // 获取工作中心
  481. getListWorkCenter() {
  482. work.list({ pageNum: 1, size: -1 }).then((res) => {
  483. this.workCenterList = res.list.map((m) => ({
  484. label: m.name,
  485. value: m.id
  486. }));
  487. });
  488. }
  489. }
  490. };
  491. </script>