Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

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