qcDataProcessor.uts 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648
  1. import { getToken, getTokenFromApi } from './auth'
  2. import { saveTaskInfo, saveTaskPhoto, saveTaskKeyProcess, saveTaskRecord, saveTaskRecordItem, getLatestTask, removeTaskAndRecord } from '@/api/work'
  3. import { globalConfig } from '@/config'
  4. // 类型定义保持不变
  5. export type ApiResponse = {
  6. code : number;
  7. msg : string;
  8. data : AppTaskInfo;
  9. }
  10. export type AppTaskInfo = {
  11. gxpk : string;
  12. pk_serial: string;
  13. cardno ?: string;
  14. productcode ?: string;
  15. model ?: string;
  16. workorder ?: string;
  17. invname ?: string;
  18. graphid ?: string;
  19. processno ?: string;
  20. ver ?: string;
  21. lastupdatetime ?: string;
  22. qcrecord ?: AppTaskRecord;
  23. photolist ?: AppTaskPhoto[];
  24. keyprocesslist ?: AppTaskKeyProcess[];
  25. }
  26. export type AppTaskRecord = {
  27. pk ?: string;
  28. fk_invcode ?: string;
  29. no ?: string;
  30. invcode ?: string;
  31. invname : string;
  32. processStep ?: string;
  33. fk_processTask ?: string;
  34. checkTarget ?: string;
  35. checknum ?: number;
  36. oknum ?: number;
  37. ngnum ?: number;
  38. status ?: string;
  39. result ?: string;
  40. checkTime ?: string;
  41. cs ?: string;
  42. ts ?: string;
  43. items ?: AppTaskRecordItem[];
  44. }
  45. export type AppTaskRecordItem = {
  46. pk ?: string;
  47. fk_qcRecord ?: string;
  48. fk_prodcode ?: string;
  49. prodno ?: string;
  50. name ?: string;
  51. no ?: string;
  52. nature ?: string;
  53. unit ?: string;
  54. maxNum ?: number;
  55. minNum ?: number;
  56. status ?: string;
  57. memo ?: string;
  58. measuredvalue ?: string;
  59. result ?: string;
  60. cs ?: string;
  61. ts ?: string;
  62. }
  63. export type AppTaskPhoto = {
  64. pk : string;
  65. photographpoint ?: string;
  66. photographdescription ?: string;
  67. photourl ?: string;
  68. photoname ?: string;
  69. fk_qcRecord ?: string;
  70. fk_prodcode ?: string;
  71. prodno ?: string;
  72. fk_creator ?: string;
  73. fks_operator ?: string;
  74. operator ?: string;
  75. processStep ?: string;
  76. fk_processTask ?: string;
  77. cs ?: string;
  78. ts ?: string;
  79. }
  80. export type AppTaskKeyProcess = {
  81. pk ?: string;
  82. pdid ?: string;
  83. testapparatus ?: string;
  84. tableid ?: string;
  85. testrequirelower ?: string;
  86. testrequireupper ?: string;
  87. parametername ?: string;
  88. parameterorder ?: string;
  89. measureunit ?: string;
  90. parameterinstruction ?: string;
  91. parameterid ?: string;
  92. fk_creator ?: string;
  93. fk_prodcode ?: string;
  94. prodno ?: string;
  95. processstep ?: string;
  96. fk_processtask ?: string;
  97. measuredvaluemin ?: string;
  98. measuredvaluemax ?: string;
  99. fks_operator ?: string;
  100. cs ?: string;
  101. ts ?: string;
  102. }
  103. export const showProgress = (index : number, title : string) => {
  104. // 在Android设备上,需要给hideLoading和showLoading之间添加延迟
  105. // 先隐藏之前的加载提示
  106. uni.hideLoading();
  107. // 添加50ms的延迟,确保hideLoading完全执行后再显示新的进度
  108. setTimeout(() => {
  109. uni.showLoading({
  110. title: `正在${title}第${index}个任务数据`,
  111. mask: true
  112. });
  113. }, 50);
  114. }
  115. //声像任务下载
  116. export const downloadDataFromAPI = async (productCode : string, callback ?: () => void) : Promise<boolean> => {
  117. try {
  118. uni.showLoading({ title: '任务开始下载' });
  119. const apiToken = await getTokenFromApi();
  120. if (apiToken == null || apiToken == '') {
  121. uni.hideLoading();
  122. uni.showToast({ title: `获取Token失败,请联系技术IT`, icon: 'error' });
  123. return false;
  124. }
  125. //校验是否已经存在未执行的产品号,若已经存在则提示用户该产品号是否需要被覆盖,
  126. //如果没有则直接保存。如果有存在已经在执行中的产品号,则提示已存在执行中的任务
  127. const infoJson = await getLatestTask(productCode, null);
  128. console.log(infoJson);
  129. if (infoJson?.['data'] != null) {
  130. let info = infoJson?.['data'] as UTSJSONObject ?? {} as UTSJSONObject
  131. // let ingNum = parseInt(info?.['pdid'] as string);
  132. //覆盖标识位
  133. let overwiteFlag = ref(false);
  134. // 先检查是否有任务正在执行中
  135. // if (info != null && ingNum > 0) {
  136. // uni.showToast({ title: `当前产品号已有任务在执行中!`, icon: 'error' });
  137. // return false;
  138. // }
  139. // 使用Promise来处理异步流程
  140. let deleteDataPromise = new Promise<boolean>((resolve) => {
  141. // if (info != null && ingNum == 0) {
  142. if (info != null) {
  143. //可以被覆盖,需要有提示框,给用户确认
  144. uni.showModal({
  145. title: '系统提示',
  146. content: '该产品号已存在任务是否覆盖掉?',
  147. cancelText: '取消',
  148. confirmText: '确定',
  149. success: function (res) {
  150. if (res.confirm) {
  151. // 标记为需要覆盖
  152. overwiteFlag.value = true;
  153. // 执行删除数据操作
  154. removeTaskAndRecord(productCode).then((recordDelResponse) => {
  155. console.log('删除数据响应:', recordDelResponse);
  156. // 删除成功,解析Promise并允许继续执行
  157. // 确保模态框已完全关闭后再解析Promise
  158. setTimeout(() => {
  159. resolve(true);
  160. }, 300);
  161. }).catch((error) => {
  162. console.error('删除数据失败:', error);
  163. uni.showToast({ title: '删除旧数据失败', icon: 'error' });
  164. resolve(false);
  165. });
  166. } else {
  167. // 用户取消覆盖
  168. overwiteFlag.value = false;
  169. resolve(false);
  170. }
  171. }
  172. });
  173. } else {
  174. // 不需要显示确认框,直接解析Promise
  175. resolve(true);
  176. }
  177. });
  178. // 等待删除数据操作完成
  179. const canContinue : boolean = await deleteDataPromise;
  180. if (!canContinue) {
  181. // 如果不能继续(删除失败或用户取消),则终止函数执行
  182. return false;
  183. }
  184. }
  185. // 直接使用async/await处理HTTP请求,避免嵌套Promise
  186. const requestResult = await new Promise<UTSJSONObject>((resolve, reject) => {
  187. uni.request({
  188. url: `${globalConfig.host}${globalConfig.downloadTaskURL}${productCode}`,
  189. method: 'GET',
  190. header: {
  191. 'token': apiToken
  192. },
  193. success: (res) => resolve(res?.['data'] as UTSJSONObject ?? {} as UTSJSONObject),
  194. fail: (err) => reject(err)
  195. });
  196. });
  197. // 处理请求结果
  198. if (requestResult != null && requestResult.code == 666) {
  199. let taskInfo = requestResult?.['data'] as UTSJSONObject ?? {} as UTSJSONObject;
  200. if (taskInfo != null) {
  201. let data = JSON.parse<AppTaskInfo>(taskInfo.toJSONString());
  202. if (data != null) {
  203. // 保存任务信息
  204. const resSave = await saveTaskInfo(taskInfo);
  205. const lastIdStr = resSave?.['lastId'] as string | null;
  206. const lastId = lastIdStr != null ? parseInt(lastIdStr) : null;
  207. if (lastId != null) {
  208. let photoList = taskInfo?.['photolist'] as UTSJSONObject[] ?? Array<UTSJSONObject>();
  209. if (photoList != null && photoList.length > 0) {
  210. const totalRecords = photoList.length;
  211. // 按顺序处理所有图片记录
  212. for (let i = 0; i < photoList.length; i++) {
  213. // 更新进度
  214. showProgress(i + 1, '下载');
  215. let photoObj = photoList[i] as UTSJSONObject;
  216. // 获取各个字段的值
  217. const pk = photoObj['pk'] as string;
  218. const photographpoint = photoObj['photographpoint'] as string | null;
  219. const photographdescription = photoObj['photographdescription'] as string | null;
  220. const photourl = photoObj['photourl'] as string | null;
  221. const photoname = photoObj['photoname'] as string | null;
  222. const fk_qcRecord = photoObj['fk_qcRecord'] as string | null;
  223. const fk_prodcode = photoObj['fk_prodcode'] as string | null;
  224. const prodno = photoObj['prodno'] as string | null;
  225. const fk_creator = photoObj['fk_creator'] as string | null;
  226. const fks_operator = photoObj['fks_operator'] as string | null;
  227. const operator = photoObj['operator'] as string | null;
  228. const processStep = photoObj['processStep'] as string | null;
  229. const fk_processTask = photoObj['fk_processTask'] as string | null;
  230. const cs = photoObj['cs'] as string | null;
  231. const ts = photoObj['ts'] as string | null;
  232. // 获取图片
  233. let imagePathsArr = [] as string[];
  234. try {
  235. // 串行执行,等待前一张图片处理完成再处理下一张
  236. const tempFilePath = await downloadAndSaveImage(pk, apiToken);
  237. if (tempFilePath != null && tempFilePath != '') {
  238. imagePathsArr.push(tempFilePath);
  239. }
  240. } catch (error) {
  241. console.error(`处理图片时出错:`, error);
  242. // 出错后继续处理下一张图片
  243. }
  244. // 拼接图片ID和路径
  245. const imagePaths = imagePathsArr.join(",");
  246. // 使用三目运算符判断,当值为null时直接插入null,否则用单引号括起来
  247. var values = `${lastId === null ? 0 : lastId},${pk === null ? '' : `'${pk}'`}, ${photographpoint === null ? 'null' : `'${photographpoint}'`}, ${photographdescription === null ? 'null' : `'${photographdescription}'`},${photourl === null ? 'null' : `'${photourl}'`},
  248. ${imagePaths === null ? 'null' : `'${imagePaths}'`},${photoname === null ? 'null' : `'${photoname}'`},${fk_qcRecord === null ? 'null' : `'${fk_qcRecord}'`},${fk_prodcode === null ? 'null' : `'${fk_prodcode}'`}, ${prodno === null ? 'null' : `'${prodno}'`},
  249. ${fk_creator === null ? 'null' : `'${fk_creator}'`},${fks_operator === null ? 'null' : `'${fks_operator}'`}, ${operator === null ? 'null' : `'${operator}'`}, ${processStep === null ? 'null' : `'${processStep}'`}, ${fk_processTask === null ? 'null' : `'${fk_processTask}'`}, ${cs === null ? 'null' : `'${cs}'`}, ${ts === null ? 'null' : `'${ts}'`}`;
  250. // 立即保存当前图片的任务信息
  251. saveTaskPhoto(values);
  252. }
  253. //保存关键工序
  254. let keyProcessList = taskInfo?.['keyprocesslist'] as UTSJSONObject[] ?? Array<UTSJSONObject>();
  255. if (keyProcessList != null && keyProcessList.length > 0) {
  256. keyProcessList.forEach(item =>{
  257. item['pdid'] = lastId;
  258. console.log(item);
  259. saveTaskKeyProcess(item);
  260. })
  261. }
  262. //保存检验记录
  263. let recordObj = taskInfo?.['qcrecord'] as UTSJSONObject ?? {} as UTSJSONObject;
  264. if (recordObj != null) {
  265. recordObj['pdid'] = lastId;
  266. const resSave = await saveTaskRecord(recordObj);
  267. const recordIdStr = resSave?.['lastId'] as string | null;
  268. const recordId = recordIdStr != null ? parseInt(recordIdStr) : null;
  269. if (recordId != null) {
  270. let recordItemList = recordObj?.['items'] as UTSJSONObject[] ?? Array<UTSJSONObject>();
  271. if (recordItemList != null && recordItemList.length > 0) {
  272. recordItemList.forEach(item =>{
  273. item['psxid'] = recordId;
  274. console.log(item);
  275. saveTaskRecordItem(item);
  276. })
  277. }
  278. }
  279. }
  280. }
  281. } else {
  282. console.log('保存媒体信息成功,但未获取到主键ID');
  283. }
  284. }
  285. }
  286. // 所有记录处理完成,显示完成提示
  287. uni.hideLoading();
  288. uni.showToast({ title: `下载完成`, icon: 'success' });
  289. if (callback != null) {
  290. callback();
  291. }
  292. return true;
  293. } else {
  294. const errorMsg = requestResult?.msg != null ? requestResult.msg : '未知错误';
  295. uni.hideLoading();
  296. uni.showToast({ title: `请求失败: ${errorMsg}`, icon: 'error' });
  297. return false;
  298. }
  299. } catch (error) {
  300. console.error('下载数据时发生错误:', error);
  301. uni.hideLoading();
  302. uni.showToast({ title: '下载失败,请重试', icon: 'error' });
  303. return false;
  304. }
  305. }
  306. // 辅助函数:下载并保存图片
  307. const downloadAndSaveImage = async (pk: string, apiToken: string): Promise<string> => {
  308. return new Promise<string>((resolve, reject) => {
  309. // 使用uni.downloadFile下载图片
  310. uni.downloadFile({
  311. url: `${globalConfig.getImgURL}${pk}`,
  312. header: {
  313. 'token': apiToken
  314. },
  315. success: (res) => {
  316. if (res.statusCode === 200) {
  317. // 等待一小段时间确保文件完全下载
  318. setTimeout(() => {
  319. // 图片下载成功,使用uni.saveImageToPhotosAlbum保存到相册
  320. uni.saveImageToPhotosAlbum({
  321. filePath: res.tempFilePath,
  322. success: () => {
  323. console.log('图片保存成功:', res.tempFilePath);
  324. // 保存成功后等待1秒再处理下一张
  325. setTimeout(() => {
  326. resolve(res.tempFilePath);
  327. }, 1000);
  328. },
  329. fail: (err) => {
  330. console.error('保存图片失败:', err);
  331. // 保存失败返回空字符串继续处理
  332. setTimeout(() => {
  333. resolve('');
  334. }, 500);
  335. }
  336. });
  337. }, 500); // 等待500ms确保文件完全下载
  338. } else {
  339. console.error('下载图片失败,状态码:', res.statusCode);
  340. reject(new Error(`下载图片失败,状态码: ${res.statusCode}`));
  341. }
  342. },
  343. fail: (err) => {
  344. console.error('请求图片失败:', err);
  345. reject(err);
  346. }
  347. });
  348. });
  349. }
  350. //声像任务上传
  351. // export const uploadDataToAPI = async (productCode : string, callback ?: () => void) : Promise<boolean> => {
  352. // try {
  353. // //暂定需要上传的数据文件
  354. // //const infoJson = await getLatestRecord(productCode, null);
  355. // const apiToken = await getTokenFromApi();
  356. // if (apiToken == null || apiToken == '') {
  357. // uni.hideLoading();
  358. // uni.showToast({ title: `获取Token失败,请联系技术IT`, icon: 'error' });
  359. // return false
  360. // }
  361. // // 获取数据
  362. // const res = await getJoinList('app_media_record as r', 'app_media_info as i', 'r.*,i.productno, i.uploadFlag', 'r.pid=i.pdid', 'i.productno', productCode, null);
  363. // let dataList = res?.['data'] as UTSJSONObject[] ?? Array<UTSJSONObject>();
  364. // console.log(dataList);
  365. // if (dataList == null || dataList.length === 0) {
  366. // uni.hideLoading();
  367. // uni.showToast({ title: '未获取到数据', icon: 'error' });
  368. // return false;
  369. // }
  370. // let doneRecordList = dataList.filter(item => item.getString("status") == '3');
  371. // console.log(doneRecordList);
  372. // if (doneRecordList.length === 0) {
  373. // uni.hideLoading();
  374. // uni.showToast({ title: '上传图片数据为空', icon: 'error' });
  375. // return false;
  376. // }
  377. // // 1. 收集所有需要上传的图片
  378. // let allImagesToUpload : UploadImg[] = [];
  379. // let processStep = 1;
  380. // for (let index = 0; index < dataList.length; index++) {
  381. // const record = dataList[index];
  382. // if (record.getString('urlpdt') == '' || record.getString('urlpdt') == null
  383. // || record.getString('pk') == '' || record.getString('pk') == null) {
  384. // continue
  385. // }
  386. // showProgress(processStep, '准备上传');
  387. // //收集图片信息
  388. // let urlpdtStr = record.getString('urlpdt');
  389. // let pk = record.getString('pk');
  390. // let urlArr = urlpdtStr?.split(",") ?? [];
  391. // for (let j = 0; j < urlArr.length; j++) {
  392. // let path = urlArr[j];
  393. // const fullFilePath = `${uni.env.USER_DATA_PATH}` + path;
  394. // allImagesToUpload.push({ pk: pk ?? '', path: fullFilePath });
  395. // }
  396. // processStep++;
  397. // }
  398. // // 2. 统计总图片数量
  399. // const totalImages = allImagesToUpload.length;
  400. // console.log(`总共需要上传${totalImages}张图片`);
  401. // if (totalImages === 0) {
  402. // uni.hideLoading();
  403. // uni.showToast({ title: '没有需要上传的图片', icon: 'none' });
  404. // return true;
  405. // }
  406. // // 3. 执行第一次上传
  407. // let failedImages : UploadImg[] = [];
  408. // let successCount = 0;
  409. // uni.showLoading({ title: `正在上传图片 (0/${totalImages})` });
  410. // for (let i = 0; i < allImagesToUpload.length; i++) {
  411. // const { pk, path } = allImagesToUpload[i];
  412. // console.log(`开始上传文件: ${path}, 索引: ${i}, apiToken: ${apiToken}, billid: ${pk}`);
  413. // try {
  414. // // 串行执行,等待前一个图片上传完成再处理下一张
  415. // await new Promise<void>((resolve, reject) => {
  416. // // 使用uni.uploadFile进行文件上传
  417. // console.log(`上传路径:${globalConfig.uploadURL}`)
  418. // const uploadTask = uni.uploadFile({
  419. // url: `${globalConfig.uploadURL}`,
  420. // filePath: path,
  421. // name: 'file', // 文件参数名
  422. // header: {
  423. // 'token': apiToken
  424. // },
  425. // formData: {
  426. // 'billid': pk
  427. // },
  428. // success: (uploadRes) => {
  429. // if (uploadRes.statusCode === 200) {
  430. // console.log(`文件${path}上传成功`, uploadRes);
  431. // // 解析响应数据
  432. // const resData = JSON.parse(uploadRes.data) as UTSJSONObject;
  433. // console.log(resData)
  434. // if (resData?.['_id'] != null && resData?.['_id'] != '') {
  435. // successCount++;
  436. // // 等待一小段时间确保文件完全上传并处理完成
  437. // setTimeout(() => {
  438. // resolve();
  439. // }, 1000);
  440. // } else {
  441. // setTimeout(() => {
  442. // reject('响应数据无效');
  443. // }, 500);
  444. // }
  445. // } else {
  446. // console.error(`文件${path}上传失败,状态码:`, uploadRes.statusCode);
  447. // setTimeout(() => {
  448. // reject(new Error(`上传失败,状态码: ${uploadRes.statusCode}`));
  449. // }, 500);
  450. // }
  451. // },
  452. // fail: (err) => {
  453. // console.error(`文件${path}上传失败`, err);
  454. // // 上传失败也继续处理下一张,但记录错误
  455. // setTimeout(() => {
  456. // reject(err);
  457. // }, 500);
  458. // },
  459. // complete: () => {
  460. // // console.log(`文件${path}上传操作完成`);
  461. // // 更新进度
  462. // uni.hideLoading();
  463. // uni.showLoading({ title: `正在上传图片 (${i + 1}/${totalImages})` });
  464. // }
  465. // });
  466. // uploadTask.onProgressUpdate((res) => {
  467. // console.log('上传进度' + res.progress);
  468. // console.log('已经上传的数据长度' + res.totalBytesSent);
  469. // console.log('预期需要上传的数据总长度' + res.totalBytesExpectedToSend);
  470. // });
  471. // });
  472. // } catch (error) {
  473. // // 捕获上传失败的错误,将失败的图片信息添加到错误数组
  474. // console.log(`处理第${i + 1}张图片时出错:`, error);
  475. // failedImages.push({ pk, path });
  476. // // 出错后继续处理下一张图片
  477. // }
  478. // // 在两次上传之间增加一个短暂的延迟,避免请求过于频繁
  479. // if (i < allImagesToUpload.length - 1) {
  480. // await new Promise<void>((resolve) => {
  481. // setTimeout(() => {
  482. // resolve()
  483. // }, 1000)
  484. // })
  485. // }
  486. // }
  487. // // 4. 执行重试逻辑(最多3次)
  488. // const maxRetries = 3;
  489. // let retryImages = [...failedImages]; // 复制初始失败的图片数组
  490. // for (let retryCount = 1; retryCount <= maxRetries; retryCount++) {
  491. // if (retryImages.length === 0) {
  492. // // 如果没有需要重试的图片,提前结束循环
  493. // break;
  494. // }
  495. // console.log(`开始第${retryCount}次重试上传失败的图片,共${retryImages.length}张`);
  496. // uni.hideLoading();
  497. // uni.showLoading({ title: `第${retryCount}次重试 (0/${retryImages.length})` });
  498. // // 创建新的错误数组,用于收集本次重试失败的图片
  499. // let currentFailedImages : UploadImg[] = [];
  500. // let currentSuccessCount = 0;
  501. // // 串行上传失败的图片
  502. // for (let i = 0; i < retryImages.length; i++) {
  503. // const { pk, path } = retryImages[i];
  504. // console.log(`重试上传文件: ${path}, 索引: ${i}, 重试次数: ${retryCount}, apiToken: ${apiToken}, billid: ${pk}`);
  505. // console.log(`重试上传路径:${globalConfig.uploadURL}`)
  506. // await new Promise<void>((resolve) => {
  507. // uni.uploadFile({
  508. // url: `${globalConfig.uploadURL}`,
  509. // filePath: path,
  510. // name: 'file',
  511. // header: {
  512. // 'token': apiToken
  513. // },
  514. // formData: {
  515. // 'billid': pk
  516. // },
  517. // success: (uploadRes) => {
  518. // if (uploadRes.statusCode === 200) {
  519. // console.log(`重试文件${path}上传成功`, uploadRes);
  520. // const resData = JSON.parse(uploadRes.data) as UTSJSONObject;
  521. // if (resData?.['_id'] != null && resData?.['_id'] != '') {
  522. // currentSuccessCount++;
  523. // } else {
  524. // currentFailedImages.push({ pk, path });
  525. // }
  526. // } else {
  527. // currentFailedImages.push({ pk, path });
  528. // }
  529. // console.log(`重试上传完成,当前成功: ${currentSuccessCount}, 当前失败: ${currentFailedImages.length}`);
  530. // resolve();
  531. // },
  532. // fail: (err) => {
  533. // console.error(`重试文件${path}上传失败`, err);
  534. // currentFailedImages.push({ pk, path });
  535. // resolve();
  536. // },
  537. // complete: () => {
  538. // // console.log(`重试文件${path}上传操作完成`);
  539. // // 更新进度
  540. // uni.hideLoading();
  541. // uni.showLoading({ title: `第${retryCount}次重试 (${i + 1}/${retryImages.length})` });
  542. // }
  543. // });
  544. // });
  545. // // 在两次上传之间增加一个短暂的延迟,避免请求过于频繁
  546. // if (i < retryImages.length - 1) {
  547. // await new Promise<void>((resolve) => {
  548. // setTimeout(() => {
  549. // resolve()
  550. // }, 1000)
  551. // })
  552. // }
  553. // }
  554. // // 更新成功数量
  555. // successCount += currentSuccessCount;
  556. // // 更新下一次重试的图片列表为本次失败的图片
  557. // retryImages = currentFailedImages;
  558. // }
  559. // // 5. 显示总结信息
  560. // const finalFailedCount = retryImages.length;
  561. // console.log(`上传总结: 总共${totalImages}张图片, 成功${successCount}张, 失败${finalFailedCount}张`);
  562. // uni.hideLoading();
  563. // // 三次重试后如果仍有失败的图片,显示提示
  564. // if (finalFailedCount > 0) {
  565. // uni.showModal({
  566. // title: '上传提示',
  567. // content: `总共需要上传${totalImages}张图片,成功${successCount}张,失败${finalFailedCount}张。\n经过${maxRetries}次重试后,仍有${finalFailedCount}张图片上传失败,请检查网络后重新上传。`,
  568. // showCancel: false
  569. // });
  570. // } else {
  571. // uni.showToast({
  572. // title: `上传完成!共${totalImages}张图片,全部成功。`,
  573. // icon: 'success'
  574. // });
  575. // }
  576. // if (callback != null) {
  577. // callback();
  578. // }
  579. // if (finalFailedCount === 0) {
  580. // let updatedData = " uploadflag = 1 "
  581. // updateData('app_media_info', updatedData, 'productno', productCode).then((res : UTSJSONObject) => {
  582. // console.log(`更新完上传标识 ${productCode}`)
  583. // });
  584. // }
  585. // return finalFailedCount === 0;
  586. // } catch (error) {
  587. // console.error(error);
  588. // uni.showToast({ title: '上传失败,请重试', icon: 'error' });
  589. // uni.hideLoading();
  590. // return false;
  591. // }
  592. // }