ceshijilu.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  1. <template>
  2. <div>
  3. <div v-if="!addStatus">
  4. <div class="stepsViewScrollH">
  5. <div class="left">
  6. <el-table :data="tpDatas" class="tableView">
  7. <el-table-column
  8. fixed
  9. prop="fileName"
  10. label="模版名称"
  11. align="center"
  12. />
  13. <el-table-column label="操作" fixed="right">
  14. <template #default="scope">
  15. <el-button
  16. link
  17. v-if="scope.row.writeData !== ''"
  18. class="btnText"
  19. type="primary"
  20. @click="downLoad(scope.row.filePath, scope.row.fileName)"
  21. >
  22. 下载
  23. </el-button>
  24. </template>
  25. </el-table-column>
  26. </el-table>
  27. </div>
  28. <div class="right">
  29. <div class="btns">
  30. <el-button type="primary" class="btn" @click="addStatus = true"
  31. >新增</el-button
  32. >
  33. </div>
  34. <div style="border-radius: 16px">
  35. <el-table :data="fileDatas" class="tableView">
  36. <el-table-column
  37. fixed
  38. prop="fileName"
  39. label="测试记录文件名称"
  40. align="center"
  41. />
  42. <el-table-column label="操作" fixed="right" width="200">
  43. <template #default="scope">
  44. <el-button
  45. link
  46. v-if="scope.row.writeData !== ''"
  47. class="btnText"
  48. type="primary"
  49. @click="downLoad(scope.row.filePath, scope.row.fileName)"
  50. >
  51. 下载
  52. </el-button>
  53. <el-button
  54. link
  55. v-if="scope.row.writeData !== ''"
  56. class="btnText"
  57. type="primary"
  58. @click="delDatas(scope.row.id)"
  59. >
  60. 删除
  61. </el-button>
  62. </template>
  63. </el-table-column>
  64. </el-table>
  65. </div>
  66. </div>
  67. </div>
  68. </div>
  69. <div v-else>
  70. <div :key="addKey" class="addForm">
  71. <div>
  72. <el-form
  73. :model="form"
  74. label-width="100px"
  75. ref="formRef"
  76. :rules="rules"
  77. >
  78. <el-form-item label="文件" prop="filePath">
  79. <FilesUpload
  80. v-model:src="form.filePath"
  81. ref="uploadRef"
  82. v-model:src-list="srcList"
  83. v-model:pdf-list="pdfUrlList"
  84. v-model:file-name-list="fileNameList"
  85. :limit="1"
  86. :generate-pdf="true"
  87. @finished="testFiles"
  88. />
  89. </el-form-item>
  90. </el-form>
  91. <div style="padding-left: 80px">
  92. <el-button class="leftBtn" @click="resetAdd">取消</el-button>
  93. <el-button class="rightBtn" @click="submit" type="primary"
  94. >确认</el-button
  95. >
  96. </div>
  97. </div>
  98. </div>
  99. </div>
  100. </div>
  101. </template>
  102. <script setup>
  103. import {
  104. templateData,
  105. addData,
  106. getData,
  107. delData,
  108. } from "@/api/prosteps/ceshijilu";
  109. import { useProcessStore } from "@/store";
  110. import { downloadFile } from "@/utils/downLoad";
  111. defineOptions({
  112. name: "Ceshijilu",
  113. });
  114. const addKey = ref(false);
  115. const addStatus = ref(false);
  116. const pdfUrlList = ref([]);
  117. const srcList = ref([]);
  118. const fileNameList = ref([]);
  119. const testFiles = () => {
  120. form.value.filePath = srcList.value[0];
  121. };
  122. const form = ref({
  123. fileName: "",
  124. });
  125. const formRef = ref(null);
  126. const rules = reactive({
  127. filePath: [{ required: true, trigger: "change" }],
  128. });
  129. const resetAdd = () => {
  130. addKey.value = !addKey.value;
  131. addStatus.value = false;
  132. form.value.filePath = "";
  133. pdfUrlList.value = [];
  134. srcList.value = [];
  135. fileNameList.value = [];
  136. };
  137. const delDatas = async (id) => {
  138. const { data, code } = await delData({
  139. id,
  140. });
  141. if (code == "200") {
  142. ElMessage.success("操作成功!");
  143. getDatas();
  144. }
  145. };
  146. //新增提交
  147. const submit = async () => {
  148. await formRef.value.validate(async (valid) => {
  149. if (valid) {
  150. const { data, code } = await addData({
  151. fileName: fileNameList.value[0],
  152. filePath: srcList.value[0],
  153. operationId: store.odersData.operationId,
  154. // pdfPath: pdfUrlList.value[0],
  155. pdfPath: srcList.value[0],
  156. processId: store.scanInfo.id,
  157. seqNo: store.scanInfo.seqNo,
  158. workOrderCode: store.odersData.workOrderCode,
  159. });
  160. if (code == "200") {
  161. ElMessage.success("新增成功!");
  162. resetAdd();
  163. getDatas();
  164. }
  165. } else {
  166. ElMessage.error("请检查表单");
  167. }
  168. });
  169. };
  170. const store = useProcessStore();
  171. const tpDatas = ref([]);
  172. const fileDatas = ref([]);
  173. const downLoad = async (url, name) => {
  174. let names = name.split(".")[0];
  175. let resUrl = url;
  176. await downloadFile(resUrl, names);
  177. };
  178. //模版数据获取
  179. const getTpDatas = async () => {
  180. const { data } = await templateData({
  181. pageNo: 1,
  182. pageSize: 999,
  183. processId: store.odersData.operationId,
  184. });
  185. tpDatas.value = data.records;
  186. };
  187. //数据列表获取
  188. const getDatas = async () => {
  189. const { data } = await getData({
  190. pageNo: 1,
  191. pageSize: 999,
  192. processId: store.scanInfo.id,
  193. });
  194. fileDatas.value = data.records;
  195. };
  196. onMounted(() => {
  197. getTpDatas();
  198. getDatas();
  199. });
  200. </script>
  201. <style lang="scss" scoped>
  202. .tableView {
  203. width: 100%;
  204. height: calc(100vh - 290px);
  205. padding: 20px 0px;
  206. border-radius: 16px;
  207. }
  208. .addForm {
  209. width: 100%;
  210. height: calc(100vh - 290px);
  211. display: flex;
  212. background-color: white;
  213. border-radius: 16px;
  214. justify-content: center;
  215. align-items: center;
  216. }
  217. .stepsViewScrollH {
  218. width: 100%;
  219. height: calc(100vh - 270px);
  220. display: flex;
  221. padding: 20px;
  222. padding-top: 0px;
  223. .left {
  224. width: 25%;
  225. height: 100%;
  226. border-radius: 16px;
  227. background-color: white;
  228. }
  229. .right {
  230. flex: 1;
  231. border-radius: 16px;
  232. margin-left: 20px;
  233. .tableView {
  234. width: 100%;
  235. height: calc(100vh - 340px);
  236. padding: 20px 0px;
  237. border-radius: 16px !important;
  238. }
  239. .btns {
  240. height: 50px;
  241. display: flex;
  242. align-items: center;
  243. background-color: rgb(241, 243, 245);
  244. .btn {
  245. height: 30px;
  246. }
  247. }
  248. }
  249. }
  250. </style>