| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591 |
- import Config from './config.js'
- import store from '@/store/index.js'
- import JSEncrypt from 'jsencrypt'
- import Http from './http.js'
- export default {
- data() {
- return {
- regExp: {
- number: /^\d{0,10}$/,
- digit: /^\d{0,10}(.?\d{0,2})$/
- }
- }
- },
- /**
- * 页面跳转
- * @param {string} to 跳转链接 /pages/index/index
- * @param {Object} param 参数 {key : value, ...}
- * @param {string} mode 模式
- */
- redirectTo(to, param, mode) {
- let url = to;
- let tabbarList = ['/pages/index/index', '/pages/goods/list', '/pages/order/list', '/pages/my/index',
- '/pages/member/list'
- ]
- for (let i = 0; i < tabbarList.length; i++) {
- if (to.indexOf(tabbarList[i]) != -1) {
- uni.switchTab({
- url: url
- })
- return;
- }
- }
- if (param != undefined) {
- Object.keys(param).forEach(function(key) {
- if (url.indexOf('?') != -1) {
- url += "&" + key + "=" + param[key];
- } else {
- url += "?" + key + "=" + param[key];
- }
- });
- }
- switch (mode) {
- case 'tabbar':
- // 跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面。
- uni.switchTab({
- url: url
- })
- break;
- case 'redirectTo':
- // 关闭当前页面,跳转到应用内的某个页面。
- uni.redirectTo({
- url: url
- });
- break;
- case 'reLaunch':
- // 关闭所有页面,打开到应用内的某个页面。
- uni.reLaunch({
- url: url
- });
- break;
- default:
- // 保留当前页面,跳转到应用内的某个页面
- uni.navigateTo({
- url: url
- });
- }
- },
- /**
- * 图片路径转换
- * @param {String} img_path 图片地址
- * @param {Object} params 参数,针对商品、相册里面的图片区分大中小,size: big、mid、small
- */
- img(img_path, params) {
- var path = "";
- if (img_path && img_path != undefined && img_path != "") {
- if (params && img_path != this.getDefaultImage().default_goods_img) {
- // 过滤默认图
- let arr = img_path.split(".");
- let suffix = arr[arr.length - 1];
- arr.pop();
- arr[arr.length - 1] = arr[arr.length - 1] + "_" + params.size.toUpperCase();
- arr.push(suffix);
- img_path = arr.join(".");
- }
- if (img_path.indexOf("http://") == -1 && img_path.indexOf("https://") == -1) {
- path = Config.imgDomain + "/" + img_path;
- } else {
- path = img_path;
- }
- }
- return path;
- },
- /**
- * 时间戳转日期格式
- * @param {Object} timeStamp
- */
- timeStampTurnTime(timeStamp, type = "") {
- if (timeStamp != undefined && timeStamp != "" && timeStamp > 0) {
- var date = new Date();
- date.setTime(timeStamp * 1000);
- var y = date.getFullYear();
- var m = date.getMonth() + 1;
- m = m < 10 ? ('0' + m) : m;
- var d = date.getDate();
- d = d < 10 ? ('0' + d) : d;
- var h = date.getHours();
- h = h < 10 ? ('0' + h) : h;
- var minute = date.getMinutes();
- var second = date.getSeconds();
- minute = minute < 10 ? ('0' + minute) : minute;
- second = second < 10 ? ('0' + second) : second;
- if (type) {
- return y + '-' + m + '-' + d;
- } else {
- return y + '-' + m + '-' + d + ' ' + h + ':' + minute + ':' + second;
- }
- } else {
- return "";
- }
- },
- /**
- * 日期格式转时间戳
- * @param {Object} timeStamp
- */
- timeTurnTimeStamp(string) {
- var f = string.split(' ', 2);
- var d = (f[0] ? f[0] : '').split('-', 3);
- var t = (f[1] ? f[1] : '').split(':', 3);
- return (new Date(
- parseInt(d[0], 10) || null,
- (parseInt(d[1], 10) || 1) - 1,
- parseInt(d[2], 10) || null,
- parseInt(t[0], 10) || null,
- parseInt(t[1], 10) || null,
- parseInt(t[2], 10) || null
- )).getTime() / 1000;
- },
- /**
- * 倒计时
- * @param {Object} seconds 秒
- */
- countDown(seconds) {
- let [day, hour, minute, second] = [0, 0, 0, 0]
- if (seconds > 0) {
- day = Math.floor(seconds / (60 * 60 * 24))
- hour = Math.floor(seconds / (60 * 60)) - (day * 24)
- minute = Math.floor(seconds / 60) - (day * 24 * 60) - (hour * 60)
- second = Math.floor(seconds) - (day * 24 * 60 * 60) - (hour * 60 * 60) - (minute * 60)
- }
- if (day < 10) {
- day = '0' + day
- }
- if (hour < 10) {
- hour = '0' + hour
- }
- if (minute < 10) {
- minute = '0' + minute
- }
- if (second < 10) {
- second = '0' + second
- }
- return {
- d: day,
- h: hour,
- i: minute,
- s: second
- };
- },
- /**
- * 数值去重
- * @param {Array} arr 数组
- * @param {string} field 字段
- */
- unique(arr, field) {
- const res = new Map();
- return arr.filter((a) => !res.has(a[field]) && res.set(a[field], 1));
- },
- /**
- * 判断值是否在数组中
- * @param {Object} elem
- * @param {Object} arr
- * @param {Object} i
- */
- inArray: function(elem, arr) {
- return arr == null ? -1 : arr.indexOf(elem);
- },
- /**
- * 获取某天日期
- * @param {Object} day
- */
- getDay: function(day) {
- var today = new Date();
- var targetday_milliseconds = today.getTime() + 1000 * 60 * 60 * 24 * day;
- today.setTime(targetday_milliseconds);
- const doHandleMonth = function(month) {
- var m = month;
- if (month.toString().length == 1) {
- m = "0" + month;
- }
- return m
- }
- var tYear = today.getFullYear();
- var tMonth = today.getMonth();
- var tDate = today.getDate();
- var tWeek = today.getDay();
- var time = parseInt(today.getTime() / 1000);
- tMonth = doHandleMonth(tMonth + 1);
- tDate = doHandleMonth(tDate);
- const week = ['周日', '周一', '周二', '周三', '周四', '周五', '周六']
- return {
- 't': time,
- 'y': tYear,
- 'm': tMonth,
- 'd': tDate,
- 'w': week[tWeek]
- };
- },
- /**
- * 图片选择加上传
- * @param {Object} params {"number":1,"sourceType":["album","camera"],"path":"image","url":""}
- * @param {Object} callback
- * @param string url
- * return array
- */
- upload: function(params, callback) {
- // #ifdef H5
- var app_type = this.isWeiXin() ? 'wechat' : 'h5';
- var app_type_name = this.isWeiXin() ? '微信公众号' : 'H5';
- // #endif
- // #ifdef MP-WEIXIN
- var app_type = 'weapp';
- var app_type_name = '微信小程序';
- // #endif
- // #ifdef MP-ALIPAY
- var app_type = 'aliapp';
- var app_type_name = '支付宝小程序';
- // #endif
- // #ifdef MP-BAIDU
- var app_type = 'baiduapp';
- var app_type_name = '百度小程序';
- // #endif
- // #ifdef MP-TOUTIAO
- var app_type = 'MP-TOUTIAO';
- var app_type_name = '头条小程序';
- // #endif
- // #ifdef MP-QQ
- var app_type = 'MP-QQ';
- var app_type_name = 'QQ小程序';
- // #endif
- var data = {
- token: uni.getStorageSync('token'),
- app_type: app_type,
- app_type_name: app_type_name
- }
- data = Object.assign(data, params);
- var _self = this;
- params.sourceType = params.sourceType || ['album', 'camera'];
- uni.chooseImage({
- count: params.number,
- sizeType: ['compressed'], //可以指定是原图还是压缩图,默认二者都有
- sourceType: params.sourceType, //从相册或者拍照
- success: async function(res) {
- const tempFilePaths = res.tempFilePaths;
- var _data = data;
- var imgs = [];
- for (var i = 0; i < tempFilePaths.length; i++) {
- var path = await _self.upload_file_server(tempFilePaths[i], _data, params.path, params.url);
- imgs.push(path);
- }
- typeof callback == 'function' && callback(imgs);
- }
- });
- },
- //上传
- upload_file_server(tempFilePath, data, path, url = "") {
- if (url) {
- var uploadUrl = Config.baseUrl + url
- } else {
- var uploadUrl = Config.baseUrl + '/shopapi/upload/' + path
- }
- uni.showLoading({
- title: '上传中...',
- mask: true
- });
- return new Promise((resolve, reject) => {
- uni.uploadFile({
- url: uploadUrl,
- filePath: tempFilePath,
- name: 'file',
- formData: data,
- success: function(res) {
- var path_str = JSON.parse(res.data);
- if (path_str.code >= 0) {
- resolve(path_str.data.pic_path);
- } else {
- reject("error");
- }
- uni.hideLoading();
- }
- });
- });
- },
- /**
- * 复制
- * @param {Object} message
- * @param {Object} callback
- */
- copy(value, callback) {
- // #ifdef H5
- var oInput = document.createElement('input'); //创建一个隐藏input(重要!)
- oInput.value = value; //赋值
- document.body.appendChild(oInput);
- oInput.select(); // 选择对象
- document.execCommand("Copy"); // 执行浏览器复制命令
- oInput.className = 'oInput';
- oInput.style.display = 'none';
- uni.hideKeyboard();
- this.showToast({
- title: '复制成功'
- });
- typeof callback == 'function' && callback();
- // #endif
- // #ifdef MP || APP-PLUS
- uni.setClipboardData({
- data: value,
- success: () => {
- typeof callback == 'function' && callback();
- }
- });
- // #endif
- },
- /**
- * 是否是微信浏览器
- */
- isWeiXin() {
- // #ifndef H5
- return false;
- // #endif
- var ua = navigator.userAgent.toLowerCase();
- if (ua.match(/MicroMessenger/i) == "micromessenger") {
- return true;
- } else {
- return false;
- }
- },
- /**
- * 显示消息提示框
- * @param {Object} params 参数
- */
- showToast(params = {}) {
- params.title = params.title || "";
- params.icon = params.icon || "none";
- params.position = params.position || 'bottom';
- params.duration = 1500;
- uni.showToast(params);
- },
- /**
- * 检测苹果X以上的手机
- */
- isIPhoneX() {
- let res = uni.getSystemInfoSync();
- if (res.model.search('iPhone X') != -1) {
- return true;
- }
- return false;
- },
- //判断安卓还是iOS
- isAndroid() {
- let platform = uni.getSystemInfoSync().platform
- if (platform == 'ios') {
- return false;
- } else if (platform == 'android') {
- return true;
- }
- },
- /**
- * 深度拷贝对象
- * @param {Object} obj
- */
- deepClone(obj) {
- const isObject = function(obj) {
- return typeof obj == 'object';
- }
- if (!isObject(obj)) {
- throw new Error('obj 不是一个对象!')
- }
- //判断传进来的是对象还是数组
- let isArray = Array.isArray(obj)
- let cloneObj = isArray ? [] : {}
- //通过for...in来拷贝
- for (let key in obj) {
- cloneObj[key] = isObject(obj[key]) ? this.deepClone(obj[key]) : obj[key]
- }
- return cloneObj
- },
- /**
- * 获取默认图
- * @param {Object} link
- */
- getDefaultImage() {
- let defaultImg = uni.getStorageSync('default_img');
- if (defaultImg) {
- defaultImg = JSON.parse(defaultImg);
- defaultImg.default_goods_img = this.img(defaultImg.default_goods_img);
- defaultImg.default_headimg = this.img(defaultImg.default_headimg);
- defaultImg.default_shop_img = this.img(defaultImg.default_shop_img);
- defaultImg.default_category_img = this.img(defaultImg.default_category_img);
- defaultImg.default_city_img = this.img(defaultImg.default_city_img);
- defaultImg.default_supply_img = this.img(defaultImg.default_supply_img);
- defaultImg.default_store_img = this.img(defaultImg.default_store_img);
- defaultImg.default_brand_img = this.img(defaultImg.default_brand_img);
- return defaultImg;
- } else {
- return {
- default_goods_img: '',
- default_headimg: '',
- default_shop_img: '',
- default_category_img: '',
- default_city_img: '',
- default_supply_img: '',
- default_store_img: '',
- default_brand_img: ''
- };
- }
- },
- /**
- * 判断手机是否为iphoneX系列
- */
- uniappIsIPhoneX() {
- let isIphoneX = false;
- let systemInfo = uni.getSystemInfoSync();
- // #ifdef MP
- if (systemInfo.model.search('iPhone X') != -1 || systemInfo.model.search('iPhone 11') != -1 || systemInfo.model.search(
- 'iPhone12') != -1) {
- isIphoneX = true;
- }
- // #endif
- // #ifdef H5
- var u = navigator.userAgent;
- var isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端
- if (isIOS) {
- if (systemInfo.screenWidth == 375 && systemInfo.screenHeight == 812 && systemInfo.pixelRatio == 3) {
- isIphoneX = true;
- } else if (systemInfo.screenWidth == 414 && systemInfo.screenHeight == 896 && systemInfo.pixelRatio == 3) {
- isIphoneX = true;
- } else if (systemInfo.screenWidth == 414 && systemInfo.screenHeight == 896 && systemInfo.pixelRatio == 2) {
- isIphoneX = true;
- }
- }
- // #endif
- return isIphoneX;
- },
- /**
- * 判断手机是否为iphone11系列
- */
- uniappIsIPhone11() {
- let isIphone11 = false;
- let systemInfo = uni.getSystemInfoSync();
- // #ifdef MP
- if (systemInfo.model.search('iPhone 11') != -1) {
- isIphone11 = true;
- }
- // #endif
- return isIphone11;
- },
- /**
- * 判断当前页面栈是否存在,如果存在,则返回该页面栈,否则跳转到该页面
- * @param {Object} url
- */
- jumpPage(url) {
- let jump = true;
- let arr = getCurrentPages().reverse();
- for (let i = 0; i < arr.length; i++) {
- if (url.indexOf(arr[i].route) != -1) {
- jump = false;
- uni.navigateBack({
- delta: i
- });
- break;
- }
- }
- if (jump) {
- this.$util.diyRedirectTo(url);
- }
- },
- /**
- * 计算两个经纬度之间的距离
- * @param {Object} lat1
- * @param {Object} lng1
- * @param {Object} lat2
- * @param {Object} lng2
- */
- getDistance(lat1, lng1, lat2, lng2) {
- var radLat1 = lat1 * Math.PI / 180.0;
- var radLat2 = lat2 * Math.PI / 180.0;
- var a = radLat1 - radLat2;
- var b = lng1 * Math.PI / 180.0 - lng2 * Math.PI / 180.0;
- var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +
- Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));
- s = s * 6378.137; // EARTH_RADIUS;
- s = Math.round(s * 10000) / 10000;
- return s;
- },
- // #ifdef H5
- /**
- * 判断该浏览器是否为safaria浏览器
- */
- isSafari() {
- let res = uni.getSystemInfoSync();
- var ua = navigator.userAgent.toLowerCase();
- if (ua.indexOf('applewebkit') > -1 && ua.indexOf('mobile') > -1 && ua.indexOf('safari') > -1 &&
- ua.indexOf('linux') === -1 && ua.indexOf('android') === -1 && ua.indexOf('chrome') === -1 &&
- ua.indexOf('ios') === -1 && ua.indexOf('browser') === -1) {
- return true;
- } else {
- return false;
- }
- },
- // #endif
- goBack(backUrl = '/pages/index/index') {
- if (getCurrentPages().length == 1) {
- this.redirectTo(backUrl);
- } else {
- uni.navigateBack();
- }
- },
- /**
- * 转换数字,保留f位
- * @param {Object} e
- * @param {Object} f
- */
- numberFixed(e, f) {
- if (!f) {
- f = 0;
- }
- return Number(e).toFixed(f);
- },
- /**
- * 获取url参数
- * @param {Object} callback
- */
- getUrlCode(callback) {
- var url = location.search;
- var theRequest = new Object();
- if (url.indexOf('?') != -1) {
- var str = url.substr(1);
- var strs = str.split('&');
- for (var i = 0; i < strs.length; i++) {
- theRequest[strs[i].split('=')[0]] = strs[i].split('=')[1];
- }
- }
- typeof callback == 'function' && callback(theRequest);
- },
- /**
- * 检测是否登录
- * @param {Object} back 返回的页面
- */
- checkToken(back) {
- if (!uni.getStorageSync('token')) {
- this.redirectTo('/pages/login/login', {
- back
- }, 'redirectTo');
- return false;
- }
- if (!uni.getStorageSync('site_id')) {
- this.redirectTo('/pages/login/login', {}, 'redirectTo');
- return false;
- }
- return true;
- }
- }
|