index.vue 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. <template>
  2. <div class="ele-body">
  3. <el-card shadow="never" v-loading="loading">
  4. <search @search="reload" ref="searchRef"> </search>
  5. <!-- 数据表格 -->
  6. <ele-pro-table
  7. ref="table"
  8. :columns="columns"
  9. :datasource="datasource"
  10. cache-key="outsourcingListDatas"
  11. >
  12. <template v-slot:code="{ row }">
  13. <el-link
  14. type="primary"
  15. :underline="false"
  16. @click="handleDetails(row)"
  17. >{{ row.code }}</el-link
  18. >
  19. </template>
  20. <template v-slot:totalWeight="{ row }">
  21. <div v-if="row.totalWeight">{{ row.totalWeight }}</div>
  22. <div v-else>无</div>
  23. </template>
  24. <template v-slot:requireDeliveryTime="{ row }">
  25. <span v-if="row.deliveryMethod == 1">{{
  26. row.requireDeliveryTime
  27. }}</span>
  28. <el-link
  29. v-if="row.deliveryMethod == 2"
  30. type="primary"
  31. :underline="false"
  32. @click.native="handleMethod(row)"
  33. >分批时间</el-link
  34. >
  35. </template>
  36. <template v-slot:type="{ row }">
  37. <div v-if="row.type == 1">采购委外</div>
  38. <div v-if="row.type == 2">直接发货委外</div>
  39. <div v-if="row.type == 3">无采购委外</div>
  40. <div v-if="row.type == 4">带料委外</div>
  41. <div v-if="row.type == 5">不带料委外</div>
  42. </template>
  43. <template v-slot:status="{ row }">
  44. <el-tag>{{
  45. row.status == 0 ? '未提交' : row.status == 1 ? '已提交' : '已发布'
  46. }}</el-tag>
  47. </template>
  48. <template v-slot:approvalStatus="{ row }">
  49. <el-tag v-if="row.approvalStatus == 0">未提交</el-tag>
  50. <el-tag v-if="row.approvalStatus == 1" type="warning">审核中</el-tag>
  51. <el-tag v-if="row.approvalStatus == 2" type="success"
  52. >审核通过</el-tag
  53. >
  54. <el-tag v-if="row.approvalStatus == 3" type="danger"
  55. >审核不通过</el-tag
  56. >
  57. </template>
  58. <template v-slot:outsourceScene="{ row }">
  59. <span>{{ row.outsourceScene | outsourceSceneText }}</span>
  60. </template>
  61. <template v-slot:technicalDrawings="{ row }">
  62. <div v-if="row.technicalDrawings && row.technicalDrawings?.length">
  63. <el-link
  64. v-for="link in row.technicalDrawings"
  65. :key="link.id"
  66. type="primary"
  67. :underline="false"
  68. @click="downloadFile(link)"
  69. >
  70. {{ link.name }}</el-link
  71. >
  72. </div>
  73. </template>
  74. <template v-slot:files="{ row }">
  75. <div v-if="row.files && row.files?.length">
  76. <el-link
  77. v-for="link in row.files"
  78. :key="link.id"
  79. type="primary"
  80. :underline="false"
  81. @click="downloadFile(link)"
  82. >
  83. {{ link.name }}</el-link
  84. >
  85. </div>
  86. </template>
  87. <template v-slot:action="{ row }">
  88. <!-- <el-link
  89. type="primary"
  90. :underline="false"
  91. @click="handleDetails(row)"
  92. >
  93. 详情
  94. </el-link> -->
  95. <el-link
  96. type="primary"
  97. v-if="row.status == 1 || row.status == 2"
  98. :underline="false"
  99. @click="handleFlow(row)"
  100. >
  101. 流程
  102. </el-link>
  103. <el-link
  104. type="primary"
  105. v-if="row.status == 0"
  106. :underline="false"
  107. @click="handleRelease(row)"
  108. >
  109. 提交
  110. </el-link>
  111. </template>
  112. </ele-pro-table>
  113. </el-card>
  114. <flow ref="flowRef"></flow>
  115. <release ref="releaseRef" @refresh="releaseRefresh"></release>
  116. <detail ref="detailsRef"></detail>
  117. <timeDialog ref="timeDialogRef"></timeDialog>
  118. </div>
  119. </template>
  120. <script>
  121. import { getList } from '@/api/outsourcing/index.js';
  122. import flow from './components/flow.vue';
  123. import search from './components/search.vue';
  124. import release from './components/release.vue';
  125. import Detail from './components/details.vue';
  126. import timeDialog from './components/timeDialog.vue';
  127. import { getFile } from '@/api/system/file';
  128. export default {
  129. components: {
  130. search,
  131. flow,
  132. release,
  133. Detail,
  134. timeDialog
  135. },
  136. data() {
  137. return {
  138. loading: false
  139. };
  140. },
  141. filters: {
  142. outsourceSceneText(text) {
  143. switch (text) {
  144. case 1:
  145. return '首工序委外';
  146. case 2:
  147. return '单工序';
  148. case 3:
  149. return '多工序';
  150. case 4:
  151. return '首工序及多工序';
  152. default:
  153. return '';
  154. }
  155. }
  156. },
  157. computed: {
  158. // 表格列配置
  159. columns() {
  160. return [
  161. {
  162. columnKey: 'index',
  163. label: '序号',
  164. type: 'index',
  165. width: 55,
  166. align: 'center',
  167. showOverflowTooltip: true,
  168. fixed: 'left'
  169. },
  170. {
  171. prop: 'batchNo',
  172. label: '批次号',
  173. align: 'center',
  174. minWidth: 100,
  175. showOverflowTooltip: true
  176. },
  177. {
  178. slot: 'code',
  179. prop: 'code',
  180. label: '委外单编码',
  181. align: 'center',
  182. showOverflowTooltip: true
  183. },
  184. {
  185. prop: 'name',
  186. label: '委外单名称',
  187. align: 'center',
  188. showOverflowTooltip: true
  189. },
  190. {
  191. prop: 'workOrderCode',
  192. label: '工单编码',
  193. align: 'center',
  194. showOverflowTooltip: true
  195. },
  196. {
  197. prop: 'taskName',
  198. label: '委外发起工序',
  199. align: 'center',
  200. showOverflowTooltip: true
  201. },
  202. {
  203. prop: 'taskNames',
  204. label: '委外工序',
  205. align: 'center',
  206. showOverflowTooltip: true
  207. },
  208. {
  209. prop: 'totalCount',
  210. label: '委外数量',
  211. align: 'center',
  212. showOverflowTooltip: true
  213. },
  214. {
  215. prop: 'totalWeight',
  216. slot: 'totalWeight',
  217. label: '委外重量',
  218. align: 'center',
  219. showOverflowTooltip: true
  220. },
  221. {
  222. slot: 'type',
  223. label: '委外类型',
  224. align: 'center'
  225. },
  226. {
  227. prop: 'outsourceScene',
  228. slot: 'outsourceScene',
  229. label: '委外场景',
  230. align: 'center',
  231. showOverflowTooltip: true
  232. },
  233. {
  234. prop: 'supplierName',
  235. label: '委外单位',
  236. align: 'center',
  237. showOverflowTooltip: true
  238. },
  239. {
  240. slot: 'requireDeliveryTime',
  241. label: '预计到货日期',
  242. align: 'center',
  243. width: 100,
  244. showOverflowTooltip: true
  245. },
  246. // {
  247. // prop: 'produceRoutingName',
  248. // label: '工艺路线',
  249. // align: 'center'
  250. // },
  251. {
  252. prop: 'warehouseName',
  253. label: '仓库',
  254. align: 'center'
  255. },
  256. {
  257. prop: 'createUserName',
  258. label: '申请人',
  259. align: 'center'
  260. },
  261. {
  262. prop: 'createTime',
  263. label: '创建时间',
  264. align: 'center',
  265. width: 100
  266. },
  267. {
  268. slot: 'status',
  269. label: '状态',
  270. align: 'center'
  271. },
  272. {
  273. slot: 'approvalStatus',
  274. label: '审核状态',
  275. align: 'center',
  276. showOverflowTooltip: true,
  277. width: 120
  278. },
  279. {
  280. label: '图片附件',
  281. slot: 'technicalDrawings',
  282. prop: 'technicalDrawings',
  283. minWidth: 100
  284. },
  285. {
  286. label: '附件',
  287. slot: 'files',
  288. prop: 'files',
  289. minWidth: 100
  290. },
  291. {
  292. prop: 'remark',
  293. label: '备注',
  294. align: 'center'
  295. },
  296. {
  297. columnKey: 'action',
  298. label: '操作',
  299. width: 140,
  300. align: 'center',
  301. resizable: false,
  302. fixed: 'right',
  303. slot: 'action',
  304. showOverflowTooltip: true
  305. }
  306. ];
  307. },
  308. clientEnvironmentId() {
  309. return this.$store.state.user.info.clientEnvironmentId;
  310. }
  311. },
  312. created() {},
  313. methods: {
  314. statusFormatter(status) {
  315. const obj = this.statusOpt.find((i) => i.value == status);
  316. return obj && obj.label;
  317. },
  318. /* 表格数据源 */
  319. datasource({ page, limit, where }) {
  320. return getList({
  321. pageNum: page,
  322. size: limit,
  323. ...where
  324. });
  325. },
  326. downloadFile(file) {
  327. getFile({ objectName: file.storePath }, file.name);
  328. },
  329. handleFlow(row) {
  330. if (!row.processInstanceId) {
  331. return this.$message.warning('暂无流程图');
  332. }
  333. this.$refs.flowRef.open(row.processInstanceId);
  334. },
  335. handleDetails(row) {
  336. this.$refs.detailsRef.open(row);
  337. },
  338. handleMethod(row) {
  339. this.$refs.timeDialogRef.open(row, 'details');
  340. },
  341. handleRelease(row) {
  342. this.$refs.releaseRef.open(row);
  343. },
  344. /* 刷新表格 */
  345. reload(where) {
  346. this.$nextTick(() => {
  347. this.$refs.table.reload({ page: 1, where });
  348. });
  349. },
  350. releaseRefresh() {
  351. this.$refs.table.reload();
  352. }
  353. }
  354. };
  355. </script>
  356. <style lang="scss" scoped></style>