index.vue 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367
  1. <template>
  2. <div class="ele-body">
  3. <el-card shadow="never">
  4. <!-- 搜索表单 -->
  5. <user-search @search="reload" />
  6. <!-- 数据表格 -->
  7. <ele-pro-table
  8. ref="table"
  9. :columns="columns"
  10. :datasource="datasource"
  11. :selection.sync="selection"
  12. row-key="id"
  13. :page-size="this.$store.state.tablePageSize"
  14. @columns-change="handleColumnChange"
  15. :cache-key="cacheKeyUrl"
  16. >
  17. <!-- 表头工具栏 -->
  18. <template v-slot:toolbar>
  19. <el-button
  20. size="small"
  21. type="primary"
  22. icon="el-icon-plus"
  23. class="ele-btn-icon"
  24. @click="openEdit()"
  25. v-if="$hasPermission('main:categoryparam:save')"
  26. >
  27. 新建
  28. </el-button>
  29. <el-button
  30. size="small"
  31. type="danger"
  32. icon="el-icon-delete"
  33. class="ele-btn-icon"
  34. @click="removeBatch"
  35. v-if="$hasPermission('main:categoryparam:delete')"
  36. plain
  37. >
  38. 删除
  39. </el-button>
  40. <!--
  41. <el-button
  42. size="small"
  43. type="primary"
  44. icon="el-icon-upload2"
  45. class="ele-btn-icon"
  46. plain
  47. >
  48. 导出
  49. </el-button>
  50. -->
  51. <el-button
  52. size="small"
  53. type="primary"
  54. icon="el-icon-download"
  55. class="ele-btn-icon"
  56. plain
  57. v-if="$hasPermission('main:stepManagement:update')"
  58. @click="uploadFile()"
  59. >
  60. 导入
  61. </el-button>
  62. </template>
  63. <template v-slot:code="{ row }">
  64. <el-link
  65. type="primary"
  66. :underline="false"
  67. @click="openEdit(row, true)"
  68. >{{ row.code }}</el-link
  69. >
  70. </template>
  71. <template v-slot:name="{ row }">
  72. <el-link
  73. type="primary"
  74. :underline="false"
  75. @click="openEdit(row, true)"
  76. >{{ row.name }}</el-link
  77. >
  78. </template>
  79. <!-- <template v-slot:name="{ row }">
  80. <span> {{ row.name }}</span>
  81. </template> -->
  82. <!-- 操作列 -->
  83. <template v-slot:action="{ row }">
  84. <el-link
  85. type="primary"
  86. :underline="false"
  87. icon="el-icon-edit"
  88. @click="openEdit(row)"
  89. v-if="$hasPermission('main:stepManagement:update')"
  90. >
  91. 修改
  92. </el-link>
  93. <!-- <el-link
  94. type="primary"
  95. :underline="false"
  96. icon="el-icon-setting"
  97. @click="openEdit(row, true)"
  98. >
  99. 详情
  100. </el-link> -->
  101. <el-popconfirm
  102. class="ele-action"
  103. title="确定要删除当前工步吗?"
  104. @confirm="remove(row)"
  105. v-if="$hasPermission('main:stepManagement:delete')"
  106. >
  107. <template v-slot:reference>
  108. <el-link type="danger" :underline="false" icon="el-icon-delete">
  109. 删除
  110. </el-link>
  111. </template>
  112. </el-popconfirm>
  113. </template>
  114. </ele-pro-table>
  115. </el-card>
  116. <!-- 编辑弹窗 -->
  117. <user-edit
  118. :visible.sync="showEdit"
  119. :data="current"
  120. :controlList="controlList"
  121. :isView="isView"
  122. @done="reload"
  123. ref="userEdit"
  124. :typeList="typeList"
  125. />
  126. <SampleParam
  127. v-if="sampleShow"
  128. :taskId="taskId"
  129. @close="close"
  130. ></SampleParam>
  131. <importDialog
  132. ref="importDialogRef"
  133. apiUrl="/main/producestep/importExcel"
  134. fileUrl="/main/producestep/downLoadTemplate"
  135. fileName="工艺_工步导入模板"
  136. @success="reload"
  137. />
  138. </div>
  139. </template>
  140. <script>
  141. import tabMixins from '@/mixins/tableColumnsMixin';
  142. import UserSearch from './components/user-search.vue';
  143. import UserEdit from './components/user-edit.vue';
  144. import UserSetting from './components/user-setting.vue';
  145. import SampleParam from './components/sampleParam.vue';
  146. import stepManagement from '@/api/technology/stepManagement';
  147. import control from '@/api/technology/control';
  148. import importDialog from '@/components/upload/comm-dialog.vue';
  149. export default {
  150. name: 'technologyProduction',
  151. mixins: [tabMixins],
  152. components: {
  153. UserSearch,
  154. UserEdit,
  155. UserSetting,
  156. SampleParam,
  157. importDialog
  158. },
  159. data() {
  160. return {
  161. moduleName: 'mainProduceStep',
  162. // 表格列配置
  163. columns: [
  164. {
  165. columnKey: 'selection',
  166. type: 'selection',
  167. width: 45,
  168. align: 'center',
  169. fixed: 'left'
  170. },
  171. {
  172. label: '序号',
  173. type: 'index',
  174. width: 55,
  175. align: 'center'
  176. },
  177. {
  178. align: 'center',
  179. prop: 'code',
  180. label: '编码',
  181. showOverflowTooltip: true,
  182. minWidth: 110,
  183. slot: 'code'
  184. },
  185. {
  186. slot: 'name',
  187. label: '名称',
  188. showOverflowTooltip: true,
  189. align: 'center',
  190. minWidth: 110
  191. },
  192. {
  193. label: '内容',
  194. prop: 'defaultValue',
  195. showOverflowTooltip: true,
  196. align: 'center',
  197. minWidth: 330
  198. },
  199. {
  200. prop: 'status',
  201. label: '状态',
  202. align: 'center',
  203. showOverflowTooltip: true,
  204. minWidth: 50,
  205. formatter: (_row) => {
  206. return ['生效', '失效'][_row.status];
  207. }
  208. },
  209. {
  210. prop: 'sort',
  211. label: '排序',
  212. // sortable: 'custom',
  213. showOverflowTooltip: true,
  214. align: 'center',
  215. minWidth: 40
  216. },
  217. {
  218. columnKey: 'action',
  219. label: '操作',
  220. width: 260,
  221. align: 'center',
  222. resizable: false,
  223. slot: 'action',
  224. showOverflowTooltip: true
  225. }
  226. ],
  227. // 表格选中数据
  228. selection: [],
  229. // 当前编辑数据
  230. current: null,
  231. // 是否显示编辑弹窗
  232. showEdit: false,
  233. // 是否显示参数弹窗
  234. showSetting: false,
  235. controlList: [],
  236. typeList: [
  237. {
  238. value: 1,
  239. label: '普通工步'
  240. },
  241. {
  242. value: 2,
  243. label: '抽样质检工步'
  244. },
  245. {
  246. value: 3,
  247. label: '普通质检工步'
  248. },
  249. {
  250. value: 4,
  251. label: '包装工步'
  252. },
  253. {
  254. value: 5,
  255. label: '入库工步'
  256. },
  257. {
  258. value: 6,
  259. label: '一工一检(常规质检)'
  260. }
  261. ],
  262. isView: false,
  263. sampleShow: false,
  264. taskId: null,
  265. cacheKeyUrl: '8aeb1092-technology-stepManagement'
  266. };
  267. },
  268. methods: {
  269. /* 表格数据源 */
  270. async datasource({ page, limit, where, order }) {
  271. const res = await stepManagement.list({
  272. ...where,
  273. ...order,
  274. pageNum: page,
  275. size: limit
  276. });
  277. return res;
  278. },
  279. /* 刷新表格 */
  280. reload(where) {
  281. this.$refs.table.reload({ page: 1, where: where });
  282. },
  283. /* 打开编辑弹窗 */
  284. openEdit(row, isView) {
  285. this.isView = !!isView;
  286. this.getControlList();
  287. this.current = row;
  288. this.showEdit = true;
  289. this.$refs.userEdit.$refs.form &&
  290. this.$refs.userEdit.$refs.form.clearValidate();
  291. },
  292. getControlList() {
  293. const params = {
  294. pageNum: 1,
  295. size: -1
  296. };
  297. control.list().then((res) => {
  298. this.controlList = res.list;
  299. });
  300. },
  301. /* 删除 */
  302. remove(row) {
  303. const loading = this.$loading({ lock: true });
  304. stepManagement
  305. .delete([row.id])
  306. .then((msg) => {
  307. loading.close();
  308. this.$message.success('删除' + msg);
  309. this.reload();
  310. })
  311. .catch((e) => {
  312. loading.close();
  313. // this.$message.error(e.message);
  314. });
  315. },
  316. /* 批量删除 */
  317. removeBatch() {
  318. if (!this.selection.length) {
  319. this.$message.error('请至少选择一条数据');
  320. return;
  321. }
  322. this.$confirm('确定要删除选中的工步吗?', '提示', {
  323. type: 'warning'
  324. })
  325. .then(() => {
  326. const loading = this.$loading({ lock: true });
  327. stepManagement
  328. .delete(this.selection.map((d) => d.id))
  329. .then((msg) => {
  330. loading.close();
  331. this.$message.success('删除' + msg);
  332. this.reload();
  333. })
  334. .catch((e) => {
  335. loading.close();
  336. // this.$message.error(e.message);
  337. });
  338. })
  339. .catch(() => {});
  340. },
  341. sampleParam(row) {
  342. this.taskId = row.id;
  343. this.sampleShow = true;
  344. },
  345. close(done) {
  346. this.sampleShow = false;
  347. },
  348. uploadFile() {
  349. this.$refs.importDialogRef.open();
  350. }
  351. }
  352. };
  353. </script>