Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

utils.ts 9.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403
  1. import { getItem, StorageKeys } from "./storage";
  2. import {OrderStatus, OrderTypes} from "@/datas/enum";
  3. //toast
  4. export const msg = (title: string = "", param: any = {}) => {
  5. if (!title) return;
  6. uni.showToast({
  7. title,
  8. duration: param.duration || 1500,
  9. mask: param.mask || false,
  10. icon: param.icon || "none",
  11. });
  12. };
  13. //确认弹窗
  14. export const confirm = (content:string,callback:Function,title:string = "",showCancel?:boolean, confimTxt = '确定') => {
  15. uni.showModal({
  16. title: title,
  17. content: content,
  18. showCancel:showCancel ?? true,
  19. confirmText:confimTxt,
  20. success: function (res) {
  21. if (res.confirm) {
  22. callback()
  23. } else if (res.cancel) {
  24. //console.log('用户点击取消');
  25. }
  26. }
  27. });
  28. };
  29. /**
  30. * 判断是否登录
  31. */
  32. export const hasLogin = () =>{
  33. const token = getItem(StorageKeys.Token);
  34. const openId = getItem(StorageKeys.OpenId);
  35. return !isBlank(token) && !isBlank(openId);
  36. }
  37. /**
  38. * 跳转页面
  39. * url:页面路径
  40. * login:是否需要判断有没有登录
  41. */
  42. export const navTo = (url: string = "", login: boolean = false) => {
  43. if (!url) {
  44. return;
  45. }
  46. if (login && !hasLogin()) {
  47. confirm('您需要登录过后才能使用此功能',()=>{
  48. uni.navigateTo({
  49. url:'/login/login',
  50. });
  51. },'温馨提示',true,'去登录');
  52. }else{
  53. uni.navigateTo({
  54. url,
  55. });
  56. }
  57. };
  58. /**
  59. * 校验格式数据格式
  60. * @param 要校验的数据
  61. * @param 什么类型格式
  62. */
  63. export const checkStr = (str:string, type:string) => {
  64. switch (type) {
  65. case 'mobile': //手机号码
  66. return /^1[3|4|5|6|7|8|9][0-9]{9}$/.test(str);
  67. case 'tel': //座机
  68. return /^(0\d{2,3}-\d{7,8})(-\d{1,4})?$/.test(str);
  69. case 'card': //身份证
  70. return /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(str);
  71. case 'mobileCode': //6位数字验证码
  72. return /^[0-9]{6}$/.test(str)
  73. case 'pwd': //密码以字母开头,长度在8~99之间,只能包含字母、数字和下划线
  74. return /^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{8,99}$/.test(str)
  75. case 'payPwd': //支付密码 6位纯数字
  76. return /^[0-9]{6}$/.test(str)
  77. case 'postal': //邮政编码
  78. return /[1-9]\d{5}(?!\d)/.test(str);
  79. case 'QQ': //QQ号
  80. return /^[1-9][0-9]{4,9}$/.test(str);
  81. case 'weixin': //微信号
  82. return /^[a-zA-Z][a-zA-Z\d_-]{5,19}$/.test(str);
  83. case 'email': //邮箱
  84. return /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/.test(str);
  85. case 'money': //金额(小数点2位)
  86. return /^\d*(?:\.\d{0,2})?$/.test(str);
  87. case 'URL': //网址
  88. return /(http|ftp|https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?/.test(str)
  89. case 'IP': //IP
  90. return /((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))/.test(str);
  91. case 'date': //日期时间
  92. return /^(\d{4})\-(\d{2})\-(\d{2}) (\d{2})(?:\:\d{2}|:(\d{2}):(\d{2}))$/.test(str) || /^(\d{4})\-(\d{2})\-(\d{2})$/
  93. .test(str)
  94. case 'number': //数字
  95. return /^[0-9]$/.test(str);
  96. case 'english': //英文
  97. return /^[a-zA-Z]+$/.test(str);
  98. case 'chinese': //中文
  99. return /^[\\u4E00-\\u9FA5]+$/.test(str);
  100. case 'lower': //小写
  101. return /^[a-z]+$/.test(str);
  102. case 'upper': //大写
  103. return /^[A-Z]+$/.test(str);
  104. case 'HTML': //HTML标记
  105. return /<("[^"]*"|'[^']*'|[^'">])*>/.test(str);
  106. default:
  107. return true;
  108. }
  109. }
  110. /**
  111. * 检查是否为空
  112. * val 数组、对象、字符串
  113. */
  114. export function isBlank(val) {
  115. if (typeof val == 'boolean') {
  116. return false;
  117. }
  118. if (typeof val == 'number') {
  119. return false;
  120. }
  121. if (val instanceof Array) {
  122. if (val.length == 0) return true;
  123. } else if (val instanceof Object) {
  124. if (JSON.stringify(val) === '{}') return true;
  125. } else {
  126. if (val == 'null' || val == null || val == 'undefined' || val == undefined || val == '') return true;
  127. return false;
  128. }
  129. return false;
  130. };
  131. //根据订单状态获取订单状态文字
  132. export const getOrderStatusName = (status) =>{
  133. switch (status){
  134. case OrderStatus.完成填写基本信息:
  135. return '申请中';
  136. break;
  137. case OrderStatus["完成个人/单位信息上传"]:
  138. return '申请中';
  139. break;
  140. case OrderStatus.完成车辆信息上传:
  141. return '申请中';
  142. break;
  143. case OrderStatus.待支付:
  144. return '待支付';
  145. break;
  146. case OrderStatus.已支付:
  147. return '已支付';
  148. break;
  149. case OrderStatus.待审核:
  150. return '待审核';
  151. break;
  152. case OrderStatus.审核不通过:
  153. return '审核不通过';
  154. break;
  155. case OrderStatus.待发货:
  156. return '待发货';
  157. break;
  158. case OrderStatus.待收货:
  159. return '待收货';
  160. break;
  161. case OrderStatus.待激活:
  162. return '待激活';
  163. break;
  164. case OrderStatus.已完成:
  165. return '已完成';
  166. break;
  167. case OrderStatus["已申请-换货"]:
  168. return '换货中';
  169. break;
  170. case OrderStatus["已申请-退货"]:
  171. return '退货中';
  172. break;
  173. case OrderStatus.已结束:
  174. return '已结束';
  175. break;
  176. case OrderStatus.退款中:
  177. return '退款中';
  178. break;
  179. case OrderStatus.退款成功:
  180. return '退款成功';
  181. break;
  182. case OrderStatus.退货成功:
  183. return '退货成功';
  184. break;
  185. case OrderStatus["换货-设备已回收"]:
  186. return '换货成功';
  187. break;
  188. default:
  189. break;
  190. }
  191. }
  192. //根据订单类型获取订单类型文字
  193. export const getOrderTypeName = (orderType) =>{
  194. switch (orderType){
  195. case OrderTypes.更换签:
  196. return '更换签';
  197. break;
  198. case OrderTypes.更换卡:
  199. return '更换卡';
  200. break;
  201. case OrderTypes.新办发行:
  202. return '新办发行';
  203. break;
  204. case OrderTypes.增补OBU:
  205. return '增补ETC设备';
  206. break;
  207. case OrderTypes.储值卡转记账卡:
  208. return '储值卡转记账卡';
  209. break;
  210. default:
  211. break;
  212. }
  213. }
  214. //根据车辆类型获取车辆名称
  215. export const getCarTypeName = (carType) =>{
  216. switch (carType){
  217. case 0:
  218. return '客车';
  219. break;
  220. case 1:
  221. return '货车';
  222. break;
  223. default:
  224. break;
  225. }
  226. }
  227. //根据ETC卡状态获取ETC卡状态文字
  228. export const getETCStatusName = (cardStatus) => {
  229. switch (cardStatus){
  230. case 0:
  231. return '申请';
  232. break;
  233. case 1:
  234. return '正常';
  235. break;
  236. case 2:
  237. return '有卡挂起';
  238. break;
  239. case 3:
  240. return '无卡挂起';
  241. break;
  242. case 4:
  243. return '有卡注销';
  244. break;
  245. case 5:
  246. return '无卡注销';
  247. break;
  248. case 6:
  249. return '卡挂失';
  250. break;
  251. case 9:
  252. return '预注销';
  253. break;
  254. case 99:
  255. return '已删除';
  256. break;
  257. default:
  258. break;
  259. }
  260. }
  261. //根据OBU状态获取OBU状态文字
  262. export const getOBUStatusName = (obuStatus) =>{
  263. switch (obuStatus){
  264. case 0:
  265. return '未安装';
  266. break;
  267. case 1:
  268. return '正常';
  269. break;
  270. case 2:
  271. return '有签挂起';
  272. break;
  273. case 3:
  274. return '无签挂起';
  275. break;
  276. case 4:
  277. return '有签注销';
  278. break;
  279. case 5:
  280. return '无签注销';
  281. break;
  282. case 6:
  283. return '标签挂失';
  284. break;
  285. case 7:
  286. return '已过户';
  287. break;
  288. case 8:
  289. return '维修中';
  290. break;
  291. case 9:
  292. return '发行申请';
  293. break;
  294. case 10:
  295. return '车型不符';
  296. break;
  297. case 11:
  298. return '已发行';
  299. break;
  300. case 99:
  301. return '已删除';
  302. break;
  303. default:
  304. break;
  305. }
  306. }
  307. //获取订单时间
  308. export const getOrderTime = (time) =>{
  309. if(!time) return '';
  310. return getFormatDate(new Date(time));
  311. }
  312. //查看大图
  313. export const checkBigImg = (current,urls) =>{
  314. uni.previewImage({
  315. current: current,
  316. urls: urls,
  317. });
  318. }
  319. //日期格式化
  320. export function getFormatDate(date, fmt?:string) {
  321. date = date == undefined ? new Date() : date;
  322. date = typeof date == 'number' ? new Date(date) : date;
  323. fmt = fmt || 'yyyy-MM-dd HH:mm:ss';
  324. var obj = {
  325. 'y': date.getFullYear(), // 年份,注意必须用getFullYear
  326. 'M': date.getMonth() + 1, // 月份,注意是从0-11
  327. 'd': date.getDate(), // 日期
  328. 'q': Math.floor((date.getMonth() + 3) / 3), // 季度
  329. 'w': date.getDay(), // 星期,注意是0-6
  330. 'H': date.getHours(), // 24小时制
  331. 'h': date.getHours() % 12 == 0 ? 12 : date.getHours() % 12, // 12小时制
  332. 'm': date.getMinutes(), // 分钟
  333. 's': date.getSeconds(), // 秒
  334. 'S': date.getMilliseconds() // 毫秒
  335. };
  336. var week = ['天', '一', '二', '三', '四', '五', '六'];
  337. for (var i in obj) {
  338. fmt = fmt.replace(new RegExp(i + '+', 'g'), function(m) {
  339. var val = obj[i] + '';
  340. if (i == 'w') return (m.length > 2 ? '星期' : '周') + week[val];
  341. for (var j = 0, len = val.length; j < m.length - len; j++) val = '0' + val;
  342. return m.length == 1 ? val : val.substring(val.length - m.length);
  343. });
  344. }
  345. return fmt;
  346. };
  347. //时间格式化
  348. export function formatTime (date:any) {
  349. const year = date.getFullYear()
  350. const month = date.getMonth() + 1
  351. const day = date.getDate()
  352. const hour = date.getHours()
  353. const minute = date.getMinutes()
  354. const second = date.getSeconds()
  355. return `${[year, month, day].map(formatNumber).join('-')}T${[hour, minute, second].map(formatNumber).join(':')}`
  356. }
  357. //有效期时间格式化
  358. export function expireDate (date:any) {
  359. const year = date.getFullYear()+10
  360. const month = date.getMonth() + 1
  361. const day = date.getDate()
  362. return `${[year, month, day].map(formatNumber).join('-')}`
  363. }
  364. export function expireDate2 (date:any) {
  365. const year = date.getFullYear()+10
  366. const month = date.getMonth() + 1
  367. const day = date.getDate()
  368. return `${[year, month, day].map(formatNumber).join('')}`
  369. }
  370. //当前时间时间格式化
  371. export function nowDate (date:any) {
  372. const year = date.getFullYear()
  373. const month = date.getMonth() + 1
  374. const day = date.getDate()
  375. return `${[year, month, day].map(formatNumber).join('-')}`
  376. }
  377. function formatNumber (n:any) {
  378. n = n.toString()
  379. return n[1] ? n : `0${n}`
  380. }