filters.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562
  1. /**
  2. * 通用过滤器和工具函数
  3. * Vue 3 版本 - 过滤器已转换为普通函数
  4. *
  5. * 注意: Vue3 移除了过滤器功能,这些函数应该作为方法或全局方法使用
  6. * 在 main.js 中通过 app.config.globalProperties 注册为全局方法
  7. */
  8. import storage from "@/utils/storage.js";
  9. import Foundation from "./Foundation.js";
  10. /**
  11. * 金钱单位置换 2999 --> 2,999.00
  12. * @param val
  13. * @param unit
  14. * @param location
  15. * @returns {*}
  16. */
  17. export function unitPrice (val, unit, location) {
  18. if (!val) val = 0;
  19. let price = Foundation.formatPrice(val);
  20. if (location === "before") {
  21. return price.substr(0, price.length - 3);
  22. }
  23. if (location === "after") {
  24. return price.substr(-2);
  25. }
  26. return (unit || "") + price;
  27. }
  28. /**
  29. * 格式化价格 1999 --> [1999,00]
  30. * @param {*} val
  31. * @returns
  32. */
  33. export function goodsFormatPrice (val) {
  34. if (typeof val == "undefined") {
  35. return val;
  36. }
  37. let valNum = new Number(val);
  38. return valNum.toFixed(2).split(".");
  39. }
  40. /**
  41. * 将内容复制到粘贴板
  42. */
  43. import { h5Copy } from "@/utils/js_sdk/h5-copy/h5-copy.js";
  44. export function setClipboard (val) {
  45. // #ifdef H5
  46. if (val === null || val === undefined) {
  47. val = "";
  48. } else val = val + "";
  49. const result = h5Copy(val);
  50. if (result === false) {
  51. uni.showToast({
  52. title: "不支持",
  53. });
  54. } else {
  55. uni.showToast({
  56. title: "复制成功",
  57. icon: "none",
  58. });
  59. }
  60. // #endif
  61. // #ifndef H5
  62. uni.setClipboardData({
  63. data: val,
  64. success: function () {
  65. uni.showToast({
  66. title: "复制成功!",
  67. duration: 2000,
  68. icon: "none",
  69. });
  70. },
  71. });
  72. // #endif
  73. }
  74. /**
  75. * 拨打电话
  76. */
  77. export function callPhone (phoneNumber) {
  78. uni.makePhoneCall({
  79. phoneNumber: phoneNumber,
  80. });
  81. }
  82. /**
  83. * 脱敏姓名
  84. */
  85. export function noPassByName (str) {
  86. if (null != str && str != undefined) {
  87. if (str.length <= 3) {
  88. return "*" + str.substring(1, str.length);
  89. } else if (str.length > 3 && str.length <= 6) {
  90. return "**" + str.substring(2, str.length);
  91. } else if (str.length > 6) {
  92. return str.substring(0, 2) + "****" + str.substring(6, str.length);
  93. }
  94. } else {
  95. return "";
  96. }
  97. }
  98. /**
  99. * 处理unix时间戳,转换为可阅读时间格式
  100. * @param unix
  101. * @param format
  102. * @returns {*|string}
  103. */
  104. export function unixToDate (unix, format) {
  105. let _format = format || "yyyy-MM-dd hh:mm:ss";
  106. const d = new Date(unix * 1000);
  107. const o = {
  108. "M+": d.getMonth() + 1,
  109. "d+": d.getDate(),
  110. "h+": d.getHours(),
  111. "m+": d.getMinutes(),
  112. "s+": d.getSeconds(),
  113. "q+": Math.floor((d.getMonth() + 3) / 3),
  114. S: d.getMilliseconds(),
  115. };
  116. if (/(y+)/.test(_format))
  117. _format = _format.replace(
  118. RegExp.$1,
  119. (d.getFullYear() + "").substr(4 - RegExp.$1.length)
  120. );
  121. for (const k in o)
  122. if (new RegExp("(" + k + ")").test(_format))
  123. _format = _format.replace(
  124. RegExp.$1,
  125. RegExp.$1.length === 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length)
  126. );
  127. return _format;
  128. }
  129. /**
  130. * 人性化显示时间
  131. *
  132. * @param {Object} datetime
  133. */
  134. export function beautifyTime (datetime = "") {
  135. if (datetime == null || datetime == undefined || !datetime) {
  136. return "";
  137. }
  138. datetime = timestampToTime(datetime).replace(/-/g, "/");
  139. let time = new Date();
  140. let outTime = new Date(datetime);
  141. if (/^[1-9]\d*$/.test(datetime)) {
  142. outTime = new Date(parseInt(datetime) * 1000);
  143. }
  144. if (time.getTime() < outTime.getTime()) {
  145. return parseTime(outTime, "{y}/{m}/{d}");
  146. }
  147. if (time.getFullYear() != outTime.getFullYear()) {
  148. return parseTime(outTime, "{y}/{m}/{d}");
  149. }
  150. if (time.getMonth() != outTime.getMonth()) {
  151. return parseTime(outTime, "{m}/{d}");
  152. }
  153. if (time.getDate() != outTime.getDate()) {
  154. let day = outTime.getDate() - time.getDate();
  155. if (day == -1) {
  156. return parseTime(outTime, "昨天 {h}:{i}");
  157. }
  158. if (day == -2) {
  159. return parseTime(outTime, "前天 {h}:{i}");
  160. }
  161. return parseTime(outTime, "{m}-{d}");
  162. }
  163. if (time.getHours() != outTime.getHours()) {
  164. return parseTime(outTime, "{h}:{i}");
  165. }
  166. let minutes = outTime.getMinutes() - time.getMinutes();
  167. if (minutes == 0) {
  168. return "刚刚";
  169. }
  170. minutes = Math.abs(minutes);
  171. return `${minutes}分钟前`;
  172. }
  173. // 时间转换
  174. function timestampToTime (timestamp) {
  175. var date = new Date(timestamp);//时间戳为10位需*1000,时间戳为13位的话不需乘1000
  176. var Y = date.getFullYear() + '-';
  177. var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-';
  178. var D = date.getDate() + ' ';
  179. var h = date.getHours() + ':';
  180. var m = date.getMinutes() + ':';
  181. var s = date.getSeconds();
  182. return Y + M + D + h + m + s;
  183. }
  184. /**
  185. * 13888888888 -> 138****8888
  186. * @param mobile
  187. * @returns {*}
  188. */
  189. export function secrecyMobile (mobile) {
  190. mobile = String(mobile);
  191. if (!/\d{11}/.test(mobile)) {
  192. return mobile;
  193. }
  194. return mobile.replace(/(\d{3})(\d{4})(\d{4})/, "$1****$3");
  195. }
  196. /**
  197. * 人性化时间显示
  198. *
  199. * @param {Object} datetime
  200. */
  201. export function formatTime (datetime) {
  202. if (datetime == null) return "";
  203. datetime = datetime.replace(/-/g, "/");
  204. let time = new Date();
  205. let outTime = new Date(datetime);
  206. if (/^[1-9]\d*$/.test(datetime)) {
  207. outTime = new Date(parseInt(datetime) * 1000);
  208. }
  209. if (
  210. time.getTime() < outTime.getTime() ||
  211. time.getFullYear() != outTime.getFullYear()
  212. ) {
  213. return parseTime(outTime, "{y}-{m}-{d} {h}:{i}");
  214. }
  215. if (time.getMonth() != outTime.getMonth()) {
  216. return parseTime(outTime, "{m}-{d} {h}:{i}");
  217. }
  218. if (time.getDate() != outTime.getDate()) {
  219. let day = outTime.getDate() - time.getDate();
  220. if (day == -1) {
  221. return parseTime(outTime, "昨天 {h}:{i}");
  222. }
  223. if (day == -2) {
  224. return parseTime(outTime, "前天 {h}:{i}");
  225. }
  226. return parseTime(outTime, "{m}-{d} {h}:{i}");
  227. }
  228. if (time.getHours() != outTime.getHours()) {
  229. return parseTime(outTime, "{h}:{i}");
  230. }
  231. let minutes = outTime.getMinutes() - time.getMinutes();
  232. if (minutes == 0) {
  233. return "刚刚";
  234. }
  235. minutes = Math.abs(minutes);
  236. return `${minutes}分钟前`;
  237. }
  238. /**
  239. * 时间格式化方法
  240. *
  241. * @param {(Object|string|number)} time
  242. * @param {String} cFormat
  243. * @returns {String | null}
  244. */
  245. export function parseTime (time, cFormat) {
  246. if (arguments.length === 0) {
  247. return null;
  248. }
  249. let date;
  250. const format = cFormat || "{y}-{m}-{d} {h}:{i}:{s}";
  251. if (typeof time === "object") {
  252. date = time;
  253. } else {
  254. if (typeof time === "string" && /^[0-9]+$/.test(time)) {
  255. time = parseInt(time);
  256. }
  257. if (typeof time === "number" && time.toString().length === 10) {
  258. time = time * 1000;
  259. console.log("时间判断为number");
  260. }
  261. date = new Date(time.replace(/-/g, "/"));
  262. }
  263. const formatObj = {
  264. y: date.getFullYear(),
  265. m: date.getMonth() + 1,
  266. d: date.getDate(),
  267. h: date.getHours(),
  268. i: date.getMinutes(),
  269. s: date.getSeconds(),
  270. a: date.getDay(),
  271. };
  272. const time_str = format.replace(/{([ymdhisa])+}/g, (result, key) => {
  273. const value = formatObj[key];
  274. // Note: getDay() returns 0 on Sunday
  275. if (key === "a") {
  276. return ["日", "一", "二", "三", "四", "五", "六"][value];
  277. }
  278. return value.toString().padStart(2, "0");
  279. });
  280. return time_str;
  281. }
  282. /**
  283. * 清除逗号
  284. *
  285. */
  286. export function clearStrComma (str) {
  287. str = str.replace(/,/g, ""); //取消字符串中出现的所有逗号
  288. return str;
  289. }
  290. /**
  291. * 判断用户是否登录
  292. * @param val 如果为auth则判断是否登录
  293. * 如果传入 auth 则为判断是否登录
  294. */
  295. export function isLogin (val) {
  296. let userInfo = storage.getUserInfo();
  297. if (val == "auth") {
  298. return userInfo && userInfo.id ? true : false;
  299. } else {
  300. return storage.getUserInfo();
  301. }
  302. }
  303. /**
  304. * 退出登录
  305. *
  306. * TODO: 需要在迁移后重新实现
  307. * 原因: 依赖 logout API 和路由跳转逻辑
  308. * 推荐: 在组件中使用 Composition API 实现
  309. */
  310. // export function quiteLoginOut () {
  311. // uni.showModal({
  312. // title: "提示",
  313. // content: "是否退出登录?",
  314. // confirmColor: '#ff3c2a',
  315. // async success (res) {
  316. // if (res.confirm) {
  317. // storage.setAccessToken("");
  318. // storage.setUserInfo({});
  319. // storage.setHasLogin(false)
  320. // navigateToLogin("redirectTo");
  321. // await logout();
  322. // }
  323. // },
  324. // });
  325. // }
  326. /**
  327. * 用户注销
  328. *
  329. * TODO: 需要在迁移后重新实现
  330. * 原因: 依赖 logoffConfirm API 和 getCurrentInstance
  331. * 推荐: 在组件中使用 Composition API 实现
  332. */
  333. // export function logoff () {
  334. // uni.showModal({
  335. // title: "提示",
  336. // content: "确认注销用户么?注销用户将无法再次登录并失去当前数据。",
  337. // confirmColor: getCurrentInstance.proxy.$mainColor,
  338. // async success (res) {
  339. // if (res.confirm) {
  340. // await logoffConfirm();
  341. // storage.setAccessToken("");
  342. // storage.setRefreshToken("");
  343. // storage.setUserInfo({});
  344. // navigateToLogin("redirectTo");
  345. // }
  346. // },
  347. // });
  348. // }
  349. /**
  350. * 跳转im
  351. *
  352. * TODO: 需要在迁移后重新实现
  353. * 原因: 依赖 isLogin 和路由跳转逻辑
  354. * 推荐: 在组件中使用 Composition API 实现
  355. */
  356. /* export function talkIm (storeId, goodsId, id) {
  357. if (isLogin('auth')) {
  358. let url = `/pages/mine/im/index?userId=${storeId}`
  359. if(goodsId && id) url = `/pages/mine/im/index?userId=${storeId}&goodsid=${goodsId}&skuid=${id}`
  360. uni.navigateTo({
  361. url
  362. });
  363. }
  364. else {
  365. tipsToLogin()
  366. }
  367. } */
  368. /**
  369. * 提示登录
  370. *
  371. * TODO: 需要在迁移后重新实现
  372. * 原因: 依赖 getCurrentInstance 和路由跳转逻辑
  373. * 推荐: 在组件中使用 Composition API 实现
  374. */
  375. /* export function tipsToLogin (type) {
  376. if (!isLogin("auth")) {
  377. uni.showModal({
  378. title: "提示",
  379. content: "当前用户未登录是否登录?",
  380. confirmText: "确定",
  381. cancelText: "取消",
  382. confirmColor: getCurrentInstance.proxy.$mainColor,
  383. success: (res) => {
  384. if (res.confirm) {
  385. navigateToLogin();
  386. } else if (res.cancel) {
  387. if(type !== 'normal'){
  388. uni.navigateBack();
  389. }
  390. }
  391. },
  392. });
  393. return false;
  394. }
  395. return true;
  396. } */
  397. /**
  398. * 获取用户信息并重新添加到缓存里面
  399. *
  400. * TODO: 需要在迁移后重新实现
  401. * 原因: 依赖 getUserInfo API
  402. * 推荐: 在组件中使用 Composition API 实现
  403. */
  404. export async function userInfo () {
  405. // TODO: 需要导入 getUserInfo API
  406. // const res = await getUserInfo();
  407. // if (res.data.success) {
  408. // storage.setUserInfo(res.data.result);
  409. // return res.data.result;
  410. // }
  411. console.warn('userInfo function needs to be implemented after migration');
  412. return null;
  413. }
  414. /**
  415. * 验证是否登录如果没登录则去登录
  416. * @param {*} val
  417. * @returns
  418. */
  419. export function forceLogin () {
  420. let userInfo = storage.getUserInfo();
  421. if (!userInfo || !userInfo.id) {
  422. // #ifdef MP-WEIXIN || MP-HARMONY
  423. uni.navigateTo({
  424. url: "/pages/passport/wechatMPLogin",
  425. });
  426. // #endif
  427. // #ifndef MP-WEIXIN || MP-HARMONY
  428. uni.navigateTo({
  429. url: "/pages/passport/login",
  430. });
  431. // #endif
  432. }
  433. }
  434. /**
  435. * 获取当前加载的页面对象
  436. * @param val
  437. */
  438. export function getPages (val) {
  439. const pages = getCurrentPages(); //获取加载的页面
  440. const currentPage = pages[pages.length - 1]; //获取当前页面的对象
  441. const url = currentPage.route; //当前页面url
  442. return val ? currentPage : url;
  443. }
  444. /**
  445. * 跳转到登录页面
  446. */
  447. export function navigateToLogin (type = "navigateTo") {
  448. /**
  449. * 此处进行条件编译判断
  450. * 微信小程序跳转到微信小程序登录页面
  451. * H5/App跳转到普通登录页面
  452. */
  453. // #ifdef MP-WEIXIN || MP-HARMONY
  454. uni[type]({
  455. url: "/pages/passport/wechatMPLogin",
  456. });
  457. // #endif
  458. // #ifndef MP-WEIXIN || MP-HARMONY
  459. uni[type]({
  460. url: "/pages/login/index",
  461. });
  462. // #endif
  463. }
  464. /**
  465. * 服务状态列表
  466. */
  467. export function serviceStatusList (val) {
  468. let statusList = {
  469. APPLY: "申请售后",
  470. PASS: "通过售后",
  471. REFUSE: "拒绝售后",
  472. BUYER_RETURN: "买家退货,待卖家收货",
  473. SELLER_RE_DELIVERY: "商家换货/补发",
  474. SELLER_CONFIRM: "卖家确认收货",
  475. SELLER_TERMINATION: "卖家终止售后",
  476. BUYER_CONFIRM: "买家确认收货",
  477. BUYER_CANCEL: "买家取消售后",
  478. WAIT_REFUND: "等待平台退款",
  479. COMPLETE: "完成售后",
  480. };
  481. return statusList[val];
  482. }
  483. /**
  484. * 订单状态列表
  485. */
  486. export function orderStatusList (val) {
  487. let orderStatusList = {
  488. UNDELIVERED: "待发货",
  489. UNPAID: "未付款",
  490. PAID: "已付款",
  491. PARTS_DELIVERED: "部分发货",
  492. DELIVERED: "已发货",
  493. CANCELLED: "已取消",
  494. COMPLETED: "已完成",
  495. COMPLETE: "已完成",
  496. TAKE: "待核验",
  497. STAY_PICKED_UP: "待自提",
  498. };
  499. return orderStatusList[val];
  500. }