bottomTable.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459
  1. <template>
  2. <div>
  3. <avue-crud
  4. ref="crudRef"
  5. v-model:search="search"
  6. v-model="form"
  7. :data="data"
  8. :option="option"
  9. v-model:page="page"
  10. @row-save="createRow"
  11. @row-update="updateRow"
  12. @row-del="deleteRow"
  13. @selection-change="selectionChange"
  14. @sortable-change="onSortChange"
  15. @search-change="searchChange"
  16. @search-reset="resetChange"
  17. @size-change="dataList"
  18. @current-change="dataList"
  19. >
  20. <template #filePath-form="scope">
  21. <!-- <single-upload v-model="form.filePath" />
  22. <FilesUpload v-model:src="form.filePath" v-model:src-list="form.filePath" /> -->
  23. <div style="height: 100px; width: 100px; overflow: hidden">
  24. <PDFView
  25. :need-to-show-pdf="true"
  26. content-type="button"
  27. :is-link="true"
  28. :show-pdf-number="form.showAppointPageNum"
  29. :pdf-source="pdfPath"
  30. />
  31. </div>
  32. </template>
  33. <template #filePath="{ row }">
  34. <PDFView
  35. :need-to-show-pdf="true"
  36. content-type="button"
  37. btnText="查看PDF"
  38. :is-link="true"
  39. :pdf-source="getSOAPpdf(row)"
  40. />
  41. </template>
  42. </avue-crud>
  43. <CommonTable
  44. ref="commonTableRef"
  45. :tableTitle="tableTitle"
  46. :tableType="commonTableType"
  47. :multipleRow="true"
  48. @selected-sure="onSelectedFinish"
  49. />
  50. <el-dialog v-model="dialogVisible">
  51. <VuePdfEmbed :source="previewImgUrl" annotation-layer text-layer />
  52. </el-dialog>
  53. <el-dialog v-model="versionDV" title="请先选择版本号" width="500" center>
  54. <el-select
  55. v-model="selectedVersion"
  56. placeholder="请先选择版本号"
  57. style="margin-bottom: 20px"
  58. >
  59. <el-option
  60. v-for="item in versionList"
  61. :key="item.id"
  62. :label="item.bomVersion"
  63. :value="item.bomVersion"
  64. />
  65. </el-select>
  66. <template #footer>
  67. <div class="dialog-footer">
  68. <el-button @click="versionDV = false">取消</el-button>
  69. <el-button type="primary" @click="goToSelectMaterial">
  70. 确定
  71. </el-button>
  72. </div>
  73. </template>
  74. </el-dialog>
  75. </div>
  76. </template>
  77. <script setup>
  78. import { ref, getCurrentInstance } from "vue";
  79. import { useCrud } from "@/hooks/userCrud";
  80. import { getTableConfig } from "./configs";
  81. import PDFView from "@/components/PDFView/index.vue";
  82. import VuePdfEmbed from "vue-pdf-embed";
  83. import {
  84. saveCompoents,
  85. getBomVersion,
  86. getRouteMaxVersion,
  87. addBatch,
  88. addEsopBatch,
  89. addCheckBatch,
  90. addFuliao,
  91. } from "@/api/craft/process/index";
  92. import SingleUpload from "@/components/Upload/SingleUpload.vue";
  93. const props = defineProps({
  94. tableTitle: {
  95. default: "",
  96. type: String,
  97. },
  98. tableType: {
  99. default: "",
  100. type: String,
  101. },
  102. });
  103. const route = useRoute();
  104. const tableConfig = getTableConfig(route.fullPath.split("/")[4]);
  105. const afterDataListToGetBomVersion = () => {
  106. toGetBomVersion();
  107. };
  108. // 传入一个url,后面不带/
  109. const { url, form, data, option, search, page, toDeleteIds, Methords, Utils } =
  110. useCrud({
  111. src: tableConfig[props.tableType].url,
  112. afterDataList: afterDataListToGetBomVersion,
  113. });
  114. const { dataList, createRow, updateRow, deleteRow, searchChange, resetChange } =
  115. Methords; //增删改查
  116. const { selectionChange, multipleUpdate } = Methords; //选中和批量删除事件
  117. const crudRef = ref(null); //crudRef.value 获取avue-crud对象
  118. const bomVersion = ref(null);
  119. const pdfPath = ref(null);
  120. // 如果物料采集列表有值,就只能选择当前的版本,否则先选择版本
  121. const versionList = ref([]);
  122. const versionDV = ref(false);
  123. const selectedVersion = ref("");
  124. const goToSelectMaterial = () => {
  125. if (!route.fullPath.split("/")[5]) {
  126. ElMessage.error("物料编号读取错误");
  127. return;
  128. }
  129. let configParam = {};
  130. configParam.materialCode = route.fullPath.split("/")[5];
  131. configParam.bomVersion = selectedVersion.value;
  132. //根据物料编码和版本号获取对应的物料BOM
  133. commonTableType.value = "MARTERIAL_BOM";
  134. nextTick(() => {
  135. commonTableRef.value?.startSelect(configParam);
  136. commonTableRef.value?.refreshDictData("bomVersion", [], "value");
  137. commonTableRef.value?.mergeOption({
  138. searchShow: true,
  139. selection: true,
  140. reserveSelection: true,
  141. });
  142. });
  143. selectedVersion.value = "";
  144. versionDV.value = false;
  145. };
  146. const startCreat = () => {
  147. if (props.tableType === "wuliaocaiji") {
  148. if (bomVersion.value) {
  149. selectedVersion.value = bomVersion.value;
  150. goToSelectMaterial();
  151. } else {
  152. getBomVersion({ materialCode: route.fullPath.split("/")[5] }).then(
  153. (res) => {
  154. versionList.value = res?.data ?? [];
  155. versionDV.value = true;
  156. }
  157. );
  158. }
  159. // if (!route.fullPath.split("/")[5]) {
  160. // ElMessage.error("物料编号读取错误");
  161. // return;
  162. // }
  163. // //根据物料编码和版本号获取对应的物料BOM
  164. // let bomParam = {
  165. // materialCode: route.fullPath.split("/")[5],
  166. // };
  167. // getBomVersion(bomParam).then((res) => {
  168. // versionList.value = res?.data ?? [];
  169. // let resListMap = [];
  170. // //说明时物料采集的添加框 进行物料采集的下拉框数据获取
  171. // res?.data.forEach((versions) => {
  172. // resListMap.push({
  173. // label: versions.bomVersion,
  174. // value: versions.bomVersion,
  175. // });
  176. // });
  177. // //查询参数
  178. // let configParam = {};
  179. // configParam.materialCode = route.fullPath.split("/")[5];
  180. // if (bomVersion.value) {
  181. // configParam.bomVersion = bomVersion.value;
  182. // }
  183. // //根据物料编码和版本号获取对应的物料BOM
  184. // commonTableType.value = "MARTERIAL_BOM";
  185. // nextTick(() => {
  186. // commonTableRef.value?.startSelect(configParam);
  187. // commonTableRef.value?.refreshDictData(
  188. // "bomVersion",
  189. // resListMap,
  190. // "value"
  191. // );
  192. // commonTableRef.value?.mergeOption({
  193. // searchShow: true,
  194. // selection: true,
  195. // reserveSelection: true,
  196. // });
  197. // });
  198. // });
  199. } else if (props.tableType === "dianjian") {
  200. commonTableType.value = "OP_CHECK";
  201. nextTick(() => {
  202. commonTableRef.value?.startSelect();
  203. commonTableRef.value?.mergeOption({
  204. selection: true,
  205. reserveSelection: true,
  206. });
  207. });
  208. } else if (props.tableType === "ESOP") {
  209. commonTableType.value = "ESOP";
  210. nextTick(() => {
  211. commonTableRef.value?.startSelect({
  212. materialCode: route.fullPath.split("/")[5],
  213. enable: 1,
  214. });
  215. commonTableRef.value?.mergeOption({
  216. selection: true,
  217. reserveSelection: true,
  218. });
  219. });
  220. } else if (props.tableType === "fuliaoCJ") {
  221. commonTableType.value = "FULIAO_CAIJI";
  222. nextTick(() => {
  223. commonTableRef.value?.startSelect({
  224. accessoriesProperty: "2", //默认直接查所有的部件辅料)
  225. });
  226. commonTableRef.value?.mergeOption({
  227. selection: true,
  228. reserveSelection: true,
  229. });
  230. });
  231. } else {
  232. crudRef.value && crudRef.value.rowAdd();
  233. }
  234. };
  235. const saveSortData = async () => {
  236. multipleUpdate();
  237. };
  238. defineExpose({ startCreat, saveSortData });
  239. const onSortChange = () => {
  240. data.value.forEach((item) => {
  241. console.log(item.id);
  242. });
  243. };
  244. const routeId = ref("");
  245. // ============公共弹窗table选择相关,物料采集等使用===============
  246. const commonTableRef = ref({});
  247. const commonTableType = ref("MARTERIAL_BOM");
  248. //批量增加物料采集
  249. const itemRecord = ref({});
  250. const itemRecordList = ref([]);
  251. //批量增加ESOP
  252. const esopItem = ref({});
  253. const esopList = ref([]);
  254. //批量增加点检
  255. const checkItem = ref({});
  256. const checkList = ref([]);
  257. const onSelectedFinish = (itemValue) => {
  258. console.log(itemValue);
  259. if (Object.keys(itemValue).length == 0) {
  260. ElMessage.error("请选择数据,数据不能为空!");
  261. }
  262. //crudRef.value && crudRef.value.rowAdd();
  263. itemRecordList.value = [];
  264. itemRecord.value.itemRecordList = [];
  265. checkList.value = [];
  266. checkItem.value.checkList = [];
  267. esopItem.value.esopList = [];
  268. esopList.value = [];
  269. if (props.tableType === "wuliaocaiji") {
  270. itemValue?.forEach((item, index) => {
  271. const recordItem = ref({});
  272. recordItem.value.itemName = item.bomMaterialName;
  273. recordItem.value.itemCode = item.bomMaterialCode;
  274. recordItem.value.itemModel = item.spec;
  275. recordItem.value.recordVersion = item.bomVersion;
  276. recordItem.value.num = item.bomMaterialNumber;
  277. recordItem.value.traceType = "S";
  278. recordItem.value.operationId = route.params.id;
  279. recordItem.value.unit = item.unit;
  280. recordItem.value.isTrace = 1;
  281. itemRecordList.value.push(recordItem.value);
  282. });
  283. itemRecord.value.operationId = route.params.id;
  284. itemRecord.value.itemRecordList = Array.from(itemRecordList.value);
  285. addBatch(itemRecord.value).then((data) => {
  286. if (data.code == "200") {
  287. dataList();
  288. ElMessage({
  289. message: data.msg,
  290. type: "success",
  291. });
  292. } else {
  293. ElMessage({
  294. message: data.msg,
  295. type: "error",
  296. });
  297. }
  298. });
  299. } else if (props.tableType === "dianjian") {
  300. itemValue?.forEach((item, index) => {
  301. const recordItem = ref({});
  302. recordItem.value.operationId = route.params.id;
  303. recordItem.value.checkName = item.checkName;
  304. recordItem.value.checkCode = item.checkCode;
  305. recordItem.value.content = item.content;
  306. recordItem.value.standard = item.standard;
  307. recordItem.value.upper = item.upper;
  308. recordItem.value.lower = item.lower;
  309. recordItem.value.unit = item.unit;
  310. checkList.value.push(recordItem.value);
  311. });
  312. checkItem.value.operationId = route.params.id;
  313. checkItem.value.checkList = Array.from(checkList.value);
  314. addCheckBatch(checkItem.value).then((data) => {
  315. if (data.code == "200") {
  316. dataList();
  317. commonTableRef.value?.mergeOption({
  318. reserveSelection: false,
  319. });
  320. ElMessage({
  321. message: data.msg,
  322. type: "success",
  323. });
  324. } else {
  325. ElMessage({
  326. message: data.msg,
  327. type: "error",
  328. });
  329. }
  330. });
  331. } else if (props.tableType === "ESOP") {
  332. itemValue?.forEach((item, index) => {
  333. const recordItem = ref({});
  334. recordItem.value.operationId = route.params.id;
  335. recordItem.value.filePath = item.pdfPath;
  336. recordItem.value.showAppointPageNum = 1;
  337. recordItem.value.drawingCode = item.drawingCode;
  338. recordItem.value.recordVersion = item.drawingVersion;
  339. recordItem.value.sortNum = item.sort;
  340. recordItem.value.title = item.drawingTitle;
  341. esopList.value.push(recordItem.value);
  342. });
  343. esopItem.value.operationId = route.params.id;
  344. esopItem.value.esopList = Array.from(esopList.value);
  345. addEsopBatch(esopItem.value).then((data) => {
  346. if (data.code == "200") {
  347. dataList();
  348. ElMessage({
  349. message: data.msg,
  350. type: "success",
  351. });
  352. } else {
  353. ElMessage({
  354. message: data.msg,
  355. type: "error",
  356. });
  357. }
  358. });
  359. } else if (props.tableType === "fuliaoCJ") {
  360. itemValue?.forEach((item, index) => {
  361. const recordItem = ref({});
  362. recordItem.value.itemName = item.materialName;
  363. recordItem.value.itemCode = item.materialCode;
  364. recordItem.value.itemModel = item.spec;
  365. recordItem.value.recordVersion = item.bomVersion;
  366. recordItem.value.num = item.materialNumber;
  367. recordItem.value.traceType = "S";
  368. recordItem.value.operationId = route.params.id;
  369. recordItem.value.unit = item.unit;
  370. recordItem.value.isTrace = 1;
  371. itemRecordList.value.push(recordItem.value);
  372. });
  373. itemRecord.value.operationId = route.params.id;
  374. itemRecord.value.itemList = Array.from(itemRecordList.value);
  375. addFuliao(itemRecord.value).then((data) => {
  376. if (data.code == "200") {
  377. dataList();
  378. ElMessage({
  379. message: data.msg,
  380. type: "success",
  381. });
  382. } else {
  383. ElMessage({
  384. message: data.msg,
  385. type: "error",
  386. });
  387. }
  388. });
  389. }
  390. };
  391. const previewImgUrl = ref("");
  392. const dialogVisible = ref(false);
  393. const imgUrlClick = (itemValue) => {
  394. previewImgUrl.value =
  395. import.meta.env.VITE_APP_UPLOAD_URL + itemValue.filePath;
  396. dialogVisible.value = true;
  397. };
  398. const getSOAPpdf = (itemValue) => {
  399. return import.meta.env.VITE_APP_UPLOAD_URL + itemValue.filePath;
  400. };
  401. onMounted(() => {
  402. routeId.value = route.fullPath.split("/")[6];
  403. search.value.operationId = route.fullPath.split("/")[4];
  404. url.value = tableConfig[props.tableType].url;
  405. option.value = Object.assign(option.value, {
  406. searchEnter: true,
  407. addBtn: false,
  408. searchShow: false,
  409. header: false,
  410. sortable: true,
  411. column: tableConfig[props.tableType].column,
  412. });
  413. dataList();
  414. toGetBomVersion();
  415. });
  416. watch(
  417. () => props.tableType,
  418. () => {
  419. routeId.value = route.fullPath.split("/")[6];
  420. url.value = tableConfig[props.tableType].url;
  421. option.value = Object.assign(option.value, {
  422. searchEnter: true,
  423. addBtn: false,
  424. searchShow: false,
  425. header: false,
  426. sortable: true,
  427. column: tableConfig[props.tableType].column,
  428. });
  429. dataList();
  430. toGetBomVersion();
  431. }
  432. );
  433. const toGetBomVersion = () => {
  434. getRouteMaxVersion(
  435. route.fullPath.split("/")[6] ? route.fullPath.split("/")[6] : routeId.value
  436. ).then(({ data }) => {
  437. bomVersion.value = data;
  438. });
  439. };
  440. </script>