Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769
  1. import { getItem, StorageKeys } from "./storage";
  2. import { OrderStatus, OrderTypes } from "@/datas/enum.ts";
  3. import { envs } from "@/utils/network/api.js";
  4. import { agentId } from "@/utils/network/difference";
  5. import {
  6. requestNew
  7. } from "@/utils/network/request.js";
  8. import {ocrDo} from "@/utils/network/api.js";
  9. export const msg = (title : string = "", param : any = {}) => {
  10. if (!title) return;
  11. uni.showToast({
  12. title,
  13. duration: param.duration || 1500,
  14. mask: param.mask || false,
  15. icon: param.icon || "none",
  16. });
  17. };
  18. //确认弹窗
  19. export const confirm = (content : string, callback : Function, title : string = "", showCancel ?: boolean, confimTxt = '确定') => {
  20. uni.showModal({
  21. title: title,
  22. content: content,
  23. showCancel: showCancel ? showCancel : true,
  24. confirmText: confimTxt,
  25. success: function (res) {
  26. if (res.confirm) {
  27. callback()
  28. } else if (res.cancel) {
  29. //console.log('用户点击取消');
  30. }
  31. }
  32. });
  33. };
  34. /**
  35. * 判断是否登录
  36. */
  37. export const hasLogin = () => {
  38. const token = getItem(StorageKeys.Token);
  39. const openId = getItem(StorageKeys.OpenId);
  40. return !isBlank(token) && !isBlank(openId);
  41. }
  42. /**
  43. * 跳转页面
  44. * url:页面路径
  45. * login:是否需要判断有没有登录
  46. */
  47. export const navTo = (url : string = "", login : boolean = false) => {
  48. if (!url) {
  49. return;
  50. }
  51. if (login && !hasLogin()) {
  52. confirm('您需要登录过后才能使用此功能', () => {
  53. uni.navigateTo({
  54. url: '/login/login',
  55. });
  56. }, '温馨提示', true, '去登录');
  57. } else {
  58. let pages = getCurrentPages();
  59. // 获取页面栈总页数
  60. // this.pagesCount = pages.length;
  61. // 如果页面栈总数大于10
  62. console.log("pages.length",pages.length)
  63. if(pages.length >= 10){
  64. // 使用重定向跳转页面
  65. uni.redirectTo({
  66. url
  67. })
  68. }else{
  69. // 如果页面栈总数小于10,则打开新页面
  70. uni.navigateTo({
  71. url,
  72. });
  73. }
  74. }
  75. };
  76. /**
  77. * 校验格式数据格式
  78. * @param 要校验的数据
  79. * @param 什么类型格式
  80. */
  81. export const checkStr = (str : string, type : string) => {
  82. switch (type) {
  83. case 'mobile': //手机号码
  84. return /^1[3|4|5|6|7|8|9][0-9]{9}$/.test(str);
  85. case 'tel': //座机
  86. return /^(0\d{2,3}-\d{7,8})(-\d{1,4})?$/.test(str);
  87. case 'card': //身份证
  88. return /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(str);
  89. case 'mobileCode': //6位数字验证码
  90. return /^[0-9]{6}$/.test(str)
  91. case 'pwd': //密码以字母开头,长度在8~99之间,只能包含字母、数字和下划线
  92. return /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,99}$/.test(str)
  93. case 'payPwd': //支付密码 6位纯数字
  94. return /^[0-9]{6}$/.test(str)
  95. case 'postal': //邮政编码
  96. return /[1-9]\d{5}(?!\d)/.test(str);
  97. case 'QQ': //QQ号
  98. return /^[1-9][0-9]{4,9}$/.test(str);
  99. case 'weixin': //微信号
  100. return /^[a-zA-Z][a-zA-Z\d_-]{5,19}$/.test(str);
  101. case 'email': //邮箱
  102. return /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/.test(str);
  103. case 'money': //金额(小数点2位)
  104. return /^\d*(?:\.\d{0,2})?$/.test(str);
  105. case 'URL': //网址
  106. return /(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/.test(str)
  107. case 'IP': //IP
  108. return /((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))/.test(str);
  109. case 'date': //日期时间
  110. return /^(\d{4})\-(\d{2})\-(\d{2}) (\d{2})(?:\:\d{2}|:(\d{2}):(\d{2}))$/.test(str) || /^(\d{4})\-(\d{2})\-(\d{2})$/
  111. .test(str)
  112. case 'number': //数字
  113. return /^[0-9]$/.test(str);
  114. case 'english': //英文
  115. return /^[a-zA-Z]+$/.test(str);
  116. case 'chinese': //中文
  117. return /^[\\u4E00-\\u9FA5]+$/.test(str);
  118. case 'lower': //小写
  119. return /^[a-z]+$/.test(str);
  120. case 'upper': //大写
  121. return /^[A-Z]+$/.test(str);
  122. case 'HTML': //HTML标记
  123. return /<("[^"]*"|'[^']*'|[^'">])*>/.test(str);
  124. default:
  125. return true;
  126. }
  127. }
  128. /**
  129. * 检查是否为空
  130. * val 数组、对象、字符串
  131. */
  132. export function isBlank(val) {
  133. if (typeof val == 'boolean') {
  134. return false;
  135. }
  136. if (typeof val == 'number') {
  137. return false;
  138. }
  139. if (val instanceof Array) {
  140. if (val.length == 0) return true;
  141. } else if (val instanceof Object) {
  142. if (JSON.stringify(val) === '{}') return true;
  143. } else {
  144. if (val == 'null' || val == null || val == 'undefined' || val == undefined || val == '') return true;
  145. return false;
  146. }
  147. return false;
  148. };
  149. //根据订单状态获取订单状态文字
  150. export const getOrderStatusName = (status) => {
  151. switch (Number(status)) {
  152. case Number(OrderStatus.完成填写基本信息):
  153. return '申请中';
  154. break;
  155. case Number(OrderStatus["完成个人/单位信息上传"]):
  156. return '申请中';
  157. break;
  158. case Number(OrderStatus.完成车辆信息上传):
  159. return '申请中';
  160. break;
  161. case Number(OrderStatus.待支付):
  162. return '待支付';
  163. break;
  164. case Number(OrderStatus.待支付3):
  165. return '申请中';
  166. break;
  167. case Number(OrderStatus.待支付2):
  168. return '待支付';
  169. break;
  170. case Number(OrderStatus.完成签约):
  171. return '完成签约';
  172. break;
  173. case Number(OrderStatus.待审核):
  174. return '待审核';
  175. break;
  176. case Number(OrderStatus.审核不通过):
  177. return '审核不通过';
  178. break;
  179. case Number(OrderStatus.待发货):
  180. return '待发货';
  181. break;
  182. case Number(OrderStatus.待收货):
  183. return '待收货';
  184. break;
  185. case Number(OrderStatus.待激活):
  186. return '待激活';
  187. break;
  188. case Number(OrderStatus.已完成):
  189. return '已完成';
  190. break;
  191. case Number(OrderStatus["已申请-换货"]):
  192. return '换货中';
  193. break;
  194. case Number(OrderStatus["已申请-退货"]):
  195. return '退货中';
  196. break;
  197. case Number(OrderStatus.已结束):
  198. return '已结束';
  199. break;
  200. case Number(OrderStatus.退款中):
  201. return '退款中';
  202. break;
  203. case Number(OrderStatus.退款成功):
  204. return '退款成功';
  205. break;
  206. case Number(OrderStatus.退货成功):
  207. return '退货成功';
  208. break;
  209. case Number(OrderStatus["换货-设备已回收"]):
  210. return '换货成功';
  211. break;
  212. case Number(OrderStatus.待加购权益):
  213. return '代加购权益';
  214. break;
  215. case Number(OrderStatus["完成车辆信息上传/待支付"]):
  216. return '待支付';
  217. break;
  218. case Number(OrderStatus["已支付/待签约"]):
  219. return '待签约';
  220. break;
  221. default:
  222. break;
  223. }
  224. }
  225. //根据订单状态获取订单状态文字
  226. export const getOrderStatusNameNew = (status) => {
  227. switch (Number(status)) {
  228. case Number(OrderStatus.完成填写基本信息):
  229. return 'shenqingzhong';
  230. break;
  231. case Number(OrderStatus["完成个人/单位信息上传"]):
  232. return 'shenqingzhong';
  233. break;
  234. case Number(OrderStatus.完成车辆信息上传):
  235. return 'shenqingzhong';
  236. break;
  237. case Number(OrderStatus.待支付):
  238. return 'daizhifu';
  239. break;
  240. case Number(OrderStatus.待支付3):
  241. return 'shenqingzhong';
  242. break;
  243. case Number(OrderStatus.待支付2):
  244. return 'daizhifu';
  245. break;
  246. case Number(OrderStatus.完成签约):
  247. return 'finishqianyue';
  248. break;
  249. case Number(OrderStatus.待审核):
  250. return 'daishenhe';
  251. break;
  252. case Number(OrderStatus.审核不通过):
  253. return 'nopass';
  254. break;
  255. case Number(OrderStatus.待发货):
  256. return 'daifanhuo';
  257. break;
  258. case Number(OrderStatus.待收货):
  259. return 'daishouhuo';
  260. break;
  261. case Number(OrderStatus.待激活):
  262. return 'dajihuo';
  263. break;
  264. case Number(OrderStatus.已完成):
  265. return 'yiwancheng';
  266. break;
  267. case Number(OrderStatus["已申请-换货"]):
  268. return 'huanhuozhong';
  269. break;
  270. case Number(OrderStatus["已申请-退货"]):
  271. return 'tuihuozhong';
  272. break;
  273. case Number(OrderStatus.已结束):
  274. return 'yijieshu';
  275. break;
  276. case Number(OrderStatus.退款中):
  277. return 'tuikuanzhong';
  278. break;
  279. case Number(OrderStatus.退款成功):
  280. return 'tuikuanchenggong';
  281. break;
  282. case Number(OrderStatus.退货成功):
  283. return 'tuihuosuccess';
  284. break;
  285. case Number(OrderStatus["换货-设备已回收"]):
  286. return 'huanhuochenggong';
  287. break;
  288. case Number(OrderStatus["完成车辆信息上传/待支付"]):
  289. return 'daizhifu';
  290. break;
  291. case Number(OrderStatus["已支付/待签约"]):
  292. return 'daiqianyue';
  293. break;
  294. default:
  295. break;
  296. }
  297. }
  298. //根据订单类型获取订单类型文字
  299. export const getOrderTypeName = (orderType) => {
  300. return OrderTypes[orderType];
  301. }
  302. //根据订单类型获取订单类型文字
  303. export const getOrderTypeNameNew = (orderType) => {
  304. return OrderTypesNew[orderType];
  305. }
  306. //根据车辆类型获取车辆名称
  307. export const getCarTypeName = (carType : any) => {
  308. switch (carType) {
  309. case 1:
  310. return '客车';
  311. break;
  312. case 2:
  313. return '货车';
  314. break;
  315. default:
  316. break;
  317. }
  318. }
  319. //根据ETC卡状态获取ETC卡状态文字
  320. export const getETCStatusName = (cardStatus) => {
  321. switch (cardStatus) {
  322. case 0:
  323. return '申请';
  324. break;
  325. case 1:
  326. return '正常';
  327. break;
  328. case 2:
  329. return '有卡挂起';
  330. break;
  331. case 3:
  332. return '无卡挂起';
  333. break;
  334. case 4:
  335. return '有卡注销';
  336. break;
  337. case 5:
  338. return '无卡注销';
  339. break;
  340. case 6:
  341. return '卡挂失';
  342. break;
  343. case 9:
  344. return '预注销';
  345. break;
  346. case 99:
  347. return '已删除';
  348. break;
  349. default:
  350. break;
  351. }
  352. }
  353. //根据OBU状态获取OBU状态文字
  354. export const getOBUStatusName = (obuStatus) => {
  355. switch (obuStatus) {
  356. case 0:
  357. return '未安装';
  358. break;
  359. case 1:
  360. return '正常';
  361. break;
  362. case 2:
  363. return '有签挂起';
  364. break;
  365. case 3:
  366. return '无签挂起';
  367. break;
  368. case 4:
  369. return '有签注销';
  370. break;
  371. case 5:
  372. return '无签注销';
  373. break;
  374. case 6:
  375. return '标签挂失';
  376. break;
  377. case 7:
  378. return '已过户';
  379. break;
  380. case 8:
  381. return '维修中';
  382. break;
  383. case 9:
  384. return '发行申请';
  385. break;
  386. case 10:
  387. return '车型不符';
  388. break;
  389. case 11:
  390. return '已发行';
  391. break;
  392. case 99:
  393. return '已删除';
  394. break;
  395. default:
  396. break;
  397. }
  398. }
  399. //获取订单时间
  400. export const getOrderTime = (time) => {
  401. if (!time) return '';
  402. return getFormatDate(new Date(time));
  403. }
  404. //替换图片路径
  405. export const strReplace = (str : string) => {
  406. let imgUrl = str.replace("http://192.168.101.145:9000", envs[process.env.NODE_ENV].baseUrl);
  407. imgUrl = imgUrl.replace("http://100.64.2.113:9000", envs[process.env.NODE_ENV].baseUrl);
  408. return imgUrl;
  409. }
  410. // 身份证号脱敏
  411. export const desensitization = (val) => {
  412. if(val){
  413. return val.replace(/^\d{14}/,'**************');
  414. }
  415. }
  416. //查看大图
  417. export const checkBigImg = (current, urls) => {
  418. uni.previewImage({
  419. current: current,
  420. urls: urls,
  421. });
  422. }
  423. //日期格式化
  424. export function getFormatDate(date, fmt ?: string) {
  425. if (date == undefined) {
  426. date = new Date()
  427. }
  428. date = typeof date == 'number' ? new Date(date) : date;
  429. fmt = fmt || 'yyyy-MM-dd HH:mm:ss';
  430. var obj = {
  431. 'y': date.getFullYear(), // 年份,注意必须用getFullYear
  432. 'M': date.getMonth() + 1, // 月份,注意是从0-11
  433. 'd': date.getDate(), // 日期
  434. 'q': Math.floor((date.getMonth() + 3) / 3), // 季度
  435. 'w': date.getDay(), // 星期,注意是0-6
  436. 'H': date.getHours(), // 24小时制
  437. 'h': date.getHours() % 12 == 0 ? 12 : date.getHours() % 12, // 12小时制
  438. 'm': date.getMinutes(), // 分钟
  439. 's': date.getSeconds(), // 秒
  440. 'S': date.getMilliseconds() // 毫秒
  441. };
  442. var week = ['天', '一', '二', '三', '四', '五', '六'];
  443. for (var i in obj) {
  444. fmt = fmt.replace(new RegExp(i + '+', 'g'), function (m) {
  445. var val = obj[i] + '';
  446. if (i == 'w') return (m.length > 2 ? '星期' : '周') + week[val];
  447. for (var j = 0, len = val.length; j < m.length - len; j++) val = '0' + val;
  448. return m.length == 1 ? val : val.substring(val.length - m.length);
  449. });
  450. }
  451. return fmt;
  452. };
  453. //时间格式化
  454. export function formatTime(date : any) {
  455. const year = date.getFullYear()
  456. const month = date.getMonth() + 1
  457. const day = date.getDate()
  458. const hour = date.getHours()
  459. const minute = date.getMinutes()
  460. const second = date.getSeconds()
  461. return `${[year, month, day].map(formatNumber).join('-')}T${[hour, minute, second].map(formatNumber).join(':')}`
  462. }
  463. export function formatTime2(date : any) {
  464. const year = date.getFullYear() + 10
  465. const month = date.getMonth() + 1
  466. const day = date.getDate()
  467. const hour = date.getHours()
  468. const minute = date.getMinutes()
  469. const second = date.getSeconds()
  470. return `${[year, month, day].map(formatNumber).join('-')}T${[hour, minute, second].map(formatNumber).join(':')}`
  471. }
  472. //有效期时间格式化
  473. export function expireDate(date : any) {
  474. const year = date.getFullYear() + 10
  475. const month = date.getMonth() + 1
  476. const day = date.getDate()
  477. return `${[year, month, day].map(formatNumber).join('-')}`
  478. }
  479. export function expireDate2(date : any) {
  480. const year = date.getFullYear() + 10
  481. const month = date.getMonth() + 1
  482. const day = date.getDate()
  483. return `${[year, month, day].map(formatNumber).join('')}`
  484. }
  485. //当前时间时间格式化
  486. export function nowDate(date : any) {
  487. const year = date.getFullYear()
  488. const month = date.getMonth() + 1
  489. const day = date.getDate()
  490. return `${[year, month, day].map(formatNumber).join('-')}`
  491. }
  492. function formatNumber(n : any) {
  493. n = n.toString()
  494. return n[1] ? n : `0${n}`
  495. }
  496. export const uploadFile = (tempImagePath, imageType) => {
  497. console.log("tempImagePath",tempImagePath,tempImagePath.size)
  498. return new Promise((resolve, reject) => {
  499. uni.uploadFile({
  500. url: 'https://qtzl.etcjz.cn/newDev/minIo/upload', //仅为示例,非真实的接口地址
  501. filePath: tempImagePath,
  502. name: 'file',
  503. formData: {
  504. 'busCode':'iaw'
  505. },
  506. success: (uploadFileRes) => {
  507. console.log("uploadFileRes",uploadFileRes,JSON.parse(uploadFileRes.data).data.ossFilePath)
  508. // let uploadFileImage = 'http://100.64.2.113:9000' + '/default-bucket/' + JSON.parse(uploadFileRes.data).data.ossFilePath
  509. // console.log("111", JSON.parse(uploadFileRes.data).data.ossFilePath,JSON.parse(uploadFileRes.data));
  510. // var data={}
  511. // if (code == "/iaw/txOcr/idCardOcr") { //身份证 imageType 1 2
  512. // data = {
  513. // source: "1",
  514. // agencyId: agentId,
  515. // imageType: imageType,
  516. // fileName: tempImagePath,
  517. // url: uploadFileImage
  518. // };
  519. // } else if (code == "/iaw/txOcr/vehicleLicenseOcr") { //行驶证 imageType 1正 2反
  520. // data = {
  521. // source: "1",
  522. // agencyId: agentId,
  523. // imageType: imageType,
  524. // fileName: tempImagePath,
  525. // imageUrl: uploadFileImage
  526. // };
  527. // } else if (code == "") { //委托书 车头照 17
  528. // let uploadFileImage = envs[process.env.NODE_ENV].baseUrl + '/default-bucket/' + JSON.parse(uploadFileRes.data).data.ossFilePath
  529. // console.log("17", uploadFileImage)
  530. // resolve(uploadFileImage)
  531. // return;
  532. // } else if (code == '/iaw/txOcr/businessLicenseOcr') { //营业执照
  533. // data = {
  534. // type: 'business_license',
  535. // url: uploadFileImage,
  536. // agencyId: agentId,
  537. // fileName: tempImagePath,
  538. // };
  539. // console.log("91", uploadFileImage)
  540. // }
  541. const options = {
  542. type: 2,
  543. data: {
  544. type: imageType,
  545. imagePath: JSON.parse(uploadFileRes.data).data.ossFilePath,
  546. },
  547. method: "POST",
  548. showLoading: true,
  549. };
  550. requestNew(ocrDo, options).then((res) => {
  551. console.log("res===",res)
  552. const data = res;
  553. console.log('输出内容=====123', data)
  554. resolve(data)
  555. });
  556. },
  557. fail:()=>{
  558. uni.showModal({
  559. title: '提示',
  560. content: '图片上传失败,请联系管理人员',
  561. success: function (res) {
  562. if (res.confirm) {
  563. console.log('用户点击确定');
  564. } else if (res.cancel) {
  565. console.log('用户点击取消');
  566. }
  567. }
  568. });
  569. }
  570. });
  571. })
  572. }
  573. /**
  574. * 获取距离当前时间的 (天数/小时数/分钟数)
  575. * @param {*} timesData '2018-05-17 16:58:00'
  576. * @returns
  577. */
  578. export function timesDiff(timesData : any) {
  579. var dateBegin = new Date();//获取当前时间
  580. var dateEnd = new Date(timesData.replace(/-/g, "/"));//将-转化为/,使用new Date
  581. var dateDiff = dateEnd.getTime() - dateBegin.getTime();//时间差的毫秒数
  582. var days = Math.floor(dateDiff / (24 * 3600 * 1000));//计算出相差天数
  583. var leave1 = dateDiff % (24 * 3600 * 1000) //计算天数后剩余的毫秒数
  584. var hours = Math.floor(leave1 / (3600 * 1000))//计算出小时数
  585. var leave2 = leave1 % (3600 * 1000) //计算小时数后剩余的毫秒数
  586. var minutes = Math.floor(leave2 / (60 * 1000))//计算相差分钟数
  587. var diffObj = {
  588. days: 0,
  589. hours: 0,
  590. minutes: 0,
  591. };
  592. if (days != 0) {
  593. diffObj.days = Math.abs(days);
  594. } else if (days == 0 && hours != 0) {
  595. diffObj.hours = hours;
  596. } else if (days == 0 && hours == 0) {
  597. diffObj.minutes = minutes;
  598. }
  599. return diffObj
  600. }
  601. // 订阅消息
  602. export function subscribeMessages() {
  603. uni.requestSubscribeMessage({
  604. tmplIds: ['aNr4T2JEtaLtR9dihM2w3NAznz4bFMkutVZCbaSTjxg'],
  605. success(res) {
  606. console.log("订阅消息", res)
  607. }
  608. })
  609. }
  610. // 通知用户消息订阅
  611. export const noticeUser = (callback : Function) => {
  612. // #ifdef MP-WEIXIN
  613. uni.requestSubscribeMessage({
  614. tmplIds: ['u7u0yO2dkYBISpox815e1S_fcUyl9B9qyxAK7aBjuho'],
  615. complete(res) {
  616. console.log("通知用户消息订阅", res)
  617. callback()
  618. }
  619. })
  620. // #endif
  621. // #ifdef MP-ALIPAY
  622. my.requestSubscribeMessage({
  623. entityIds: [
  624. 'f1f2d14d608e48dca5c4f4775d3d2424'
  625. ],
  626. complete(res) {
  627. console.log("通知用户消息订阅", res)
  628. callback()
  629. }
  630. })
  631. // #endif
  632. }
  633. // 压缩图片
  634. export const compressImage = (tempFilePaths : any,scall, callback : Function) => {
  635. uni.compressImage({
  636. src: tempFilePaths, // 图片路径
  637. quality: 80, // 压缩质量,范围为0 - 100,100为不压缩
  638. success: function (res) {
  639. console.log('压缩后的图片路径:' + res.tempFilePath,res)
  640. callback(res)
  641. },
  642. fail: function (err) {
  643. console.error('压缩失败:' + err)
  644. }
  645. })
  646. }
  647. export const chooseImageCompress = ( callback : Function) => {
  648. uni.chooseImage({
  649. count: 1, //只能选取一张照片
  650. sizeType: ["original", "compressed"], //可以指定是原图还是压缩图,默认二者都有
  651. sourceType: ["album"], //从相册选择
  652. success: function (res) {
  653. let scall=res.tempFiles[0].size/1024/1024/2
  654. console.log("scall",scall)
  655. console.log("res.tempFiles[0].size", res.tempFilePaths[0], res.tempFiles[0].size/1024/1024)
  656. // if(scall>1){
  657. // console.log("压缩")
  658. // let quality=100
  659. // if(scall<2){
  660. // quality=80
  661. // }else if(scall>=3 && scall<4){
  662. // quality=75
  663. // }else if(scall>=4 && scall<5){
  664. // quality=60
  665. // }else if(scall>=5 && scall<6){
  666. // quality=1
  667. // }else{
  668. // quality=0
  669. // }
  670. // uni.compressImage({
  671. // src: res.tempFilePaths[0], // 图片路径
  672. // quality: quality, // 压缩质量,范围为0 - 100,100为不压缩
  673. // success: function (res) {
  674. // console.log('压缩后的图片路径:' + res.tempFilePath,res)
  675. // callback(res)
  676. // },
  677. // fail: function (err) {
  678. // console.error('压缩失败:' + err)
  679. // }
  680. // })
  681. // }else{
  682. callback(res)
  683. // }
  684. },
  685. })
  686. }
  687. // 身份证有效期是否过期
  688. export function compareDates(specifiedDateString) {
  689. const newTime=specifiedDateString.substring(0,4)+"-"+specifiedDateString.substring(4,6)+"-"+specifiedDateString.substring(6,8)
  690. console.log("newTime",newTime)
  691. const currentDate = new Date();
  692. const specifiedDate = new Date(newTime);
  693. if (currentDate > specifiedDate) {
  694. console.log("当前日期晚于指定日期")
  695. msg("身份证过期请重新上传", {
  696. 'duration': 2000
  697. })
  698. return "当前日期晚于指定日期";
  699. } else if (currentDate < specifiedDate) {
  700. console.log("当前日期早于指定日期")
  701. return "当前日期早于指定日期";
  702. } else {
  703. console.log("当前日期等于指定日期")
  704. return "当前日期等于指定日期";
  705. }
  706. }
  707. // 示例使用
  708. // const dateComparison = compareDates('2023-12-31');
  709. // console.log(dateComparison);
  710. // 跳转运维小程序
  711. export function jumpOldMini() {
  712. uni.navigateToMiniProgram({
  713. appId: "wx008c60533388527a",
  714. path: `pages/main/serve/serve`,
  715. envVersion: "release",
  716. success(res) {
  717. console.log('成功', res);
  718. },
  719. fail(res) {
  720. console.log('失败' + res);
  721. },
  722. });
  723. }
  724. // 图片转base64
  725. export const getFileBase64 = (path) => {
  726. console.log("进来",path)
  727. return new Promise((resolve, reject) => {
  728. uni.getFileSystemManager().readFile({
  729. filePath: path, //参数path:图片相对路径
  730. encoding: 'base64',
  731. success: (res) => {
  732. console.log("进来1",res)
  733. resolve(res.data);
  734. },
  735. fail: (err) => {
  736. console.log(err);
  737. }
  738. });
  739. });
  740. };