index.vue 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. <template>
  2. <div class="ele-body">
  3. <el-card shadow="never">
  4. <!-- 搜索表单 -->
  5. <user-search @search="reload" />
  6. <!-- 数据表格 -->
  7. <ele-pro-table ref="table" :columns="columns" :datasource="datasource" :selection.sync="selection" row-key="id">
  8. <!-- 表头工具栏 -->
  9. <template v-slot:toolbar>
  10. <el-button size="small" type="primary" icon="el-icon-plus" class="ele-btn-icon"
  11. @click="openEdit(null)">新增</el-button>
  12. <el-button size="small" type="primary" icon="el-icon-refresh-left" class="ele-btn-icon" @click='refreshData'
  13. :loading="loading">刷新</el-button>
  14. </template>
  15. <template v-slot:code="{ row }">
  16. <el-link type="primary" :underline="false" @click="openDetail(row)"> {{ row.code }}</el-link>
  17. </template>
  18. <!-- 状态列 -->
  19. <template v-slot:status="{ row }">
  20. {{ checkStatus(row) }}
  21. </template>
  22. <template v-slot:routeType="{ row }">
  23. {{ row.routeType == 2 ? '委外' : '生产' }}
  24. </template>
  25. <!-- 操作列 -->
  26. <template v-slot:action="{ row }">
  27. <el-link type="primary" :underline="false" icon="el-icon-edit" @click="openEdit(row)">
  28. 修改
  29. </el-link>
  30. <el-link type="primary" :underline="false" icon="el-icon-document" @click="openHistory(row)">
  31. 历史版本
  32. </el-link>
  33. <el-popconfirm v-if="row.status != 1" class="ele-action" title="确定要删除当前工序吗?" @confirm="remove(row)">
  34. <template v-slot:reference>
  35. <el-link type="danger" :underline="false" icon="el-icon-delete">
  36. 删除
  37. </el-link>
  38. </template>
  39. </el-popconfirm>
  40. </template>
  41. </ele-pro-table>
  42. </el-card>
  43. <!-- 编辑弹窗 -->
  44. <user-edit :visible.sync="showEdit" :data="current" @done="reload" ref="userEdit" />
  45. <!-- 历史版本弹框 -->
  46. <historyModal ref="historyRefs"></historyModal>
  47. <UserDetail :visible.sync="detailEdit" :data="current" @close="detailEdit = false"></UserDetail>
  48. </div>
  49. </template>
  50. <script>
  51. import UserSearch from './components/user-search.vue';
  52. import UserEdit from './components/user-edit.vue';
  53. import UserDetail from './components/user-detail.vue'
  54. import historyModal from './components/historyModal.vue'
  55. import route from '@/api/technology/route';
  56. export default {
  57. name: 'technologyRoute',
  58. components: {
  59. UserSearch,
  60. UserEdit,
  61. UserDetail,
  62. historyModal
  63. },
  64. data() {
  65. return {
  66. // 表格列配置
  67. columns: [
  68. {
  69. prop: 'code',
  70. label: '工艺路线组编码',
  71. showOverflowTooltip: true,
  72. align: 'center',
  73. minWidth: 110,
  74. slot: 'code',
  75. },
  76. {
  77. prop: 'name',
  78. label: '工艺路线名称',
  79. showOverflowTooltip: true,
  80. align: 'center',
  81. minWidth: 110
  82. },
  83. {
  84. prop: 'version',
  85. label: '工艺路线版本',
  86. align: 'center',
  87. showOverflowTooltip: true,
  88. minWidth: 110
  89. },
  90. {
  91. prop: 'produceVersionName',
  92. label: '生产版本',
  93. align: 'center',
  94. showOverflowTooltip: true
  95. },
  96. {
  97. prop: 'status',
  98. label: '状态',
  99. align: 'center',
  100. slot: 'status',
  101. showOverflowTooltip: true,
  102. minWidth: 110
  103. },
  104. {
  105. prop: 'routeType',
  106. label: '类型',
  107. align: 'center',
  108. showOverflowTooltip: true
  109. },
  110. {
  111. columnKey: 'action',
  112. label: '操作',
  113. width: 220,
  114. align: 'left',
  115. resizable: false,
  116. slot: 'action',
  117. }
  118. ],
  119. // 表格选中数据
  120. selection: [],
  121. // 当前编辑数据
  122. current: null,
  123. // 是否显示编辑弹窗
  124. showEdit: false,
  125. detailEdit: false,
  126. statusList: [
  127. { label: '草稿', value: -1 },
  128. { label: '失效', value: 0 },
  129. { label: '生效', value: 1 }
  130. ],
  131. loading: false
  132. };
  133. },
  134. methods: {
  135. /* 表格数据源 */
  136. async datasource({ page, limit, where, order }) {
  137. const res = await route.list({
  138. ...where,
  139. ...order,
  140. pageNum: page,
  141. size: limit
  142. });
  143. return res;
  144. },
  145. checkStatus(row) {
  146. let obj = this.statusList.find((it) => it.value == row.status);
  147. return obj.label;
  148. },
  149. /* 刷新表格 */
  150. reload(where) {
  151. this.$refs.table.reload({ page: 1, where: where });
  152. },
  153. /* 打开编辑弹窗 */
  154. openEdit(row) {
  155. this.current = row;
  156. this.showEdit = true;
  157. this.$refs.userEdit.$refs.form &&
  158. this.$refs.userEdit.$refs.form.clearValidate();
  159. },
  160. /* 打开历史版本 */
  161. openHistory(row) {
  162. this.$refs.historyRefs.open(row)
  163. },
  164. /* 删除 */
  165. remove(row) {
  166. const loading = this.$loading({ lock: true });
  167. route
  168. .delete(row.id)
  169. .then((msg) => {
  170. loading.close();
  171. this.$message.success('删除' + msg);
  172. this.reload();
  173. })
  174. .catch((e) => {
  175. loading.close();
  176. // this.$message.error(e.message);
  177. });
  178. },
  179. /* 批量删除 */
  180. removeBatch() {
  181. if (!this.selection.length) {
  182. this.$message.error('请至少选择一条数据');
  183. return;
  184. }
  185. this.$confirm('确定要删除选中的工序吗?', '提示', {
  186. type: 'warning'
  187. })
  188. .then(() => {
  189. const loading = this.$loading({ lock: true });
  190. producetask
  191. .delete(this.selection.map((d) => d.id))
  192. .then((msg) => {
  193. loading.close();
  194. this.$message.success('删除' + msg);
  195. this.reload();
  196. })
  197. .catch((e) => {
  198. loading.close();
  199. // this.$message.error(e.message);
  200. });
  201. })
  202. .catch(() => { });
  203. },
  204. // 刷新数据
  205. refreshData() {
  206. this.loading = true;
  207. route.syncRouting().then(res => {
  208. if (res == '0') {
  209. this.loading = false;
  210. this.$message.success('数据刷新成功!')
  211. this.reload()
  212. }
  213. })
  214. .catch((e) => {
  215. this.loading = false;
  216. });
  217. },
  218. openDetail(row) {
  219. this.current = row
  220. this.detailEdit = true
  221. },
  222. }
  223. };
  224. </script>