123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- var api = require('../config/api.js');
- function formatTime(date) {
- var year = date.getFullYear()
- var month = date.getMonth() + 1
- var day = date.getDate()
- var hour = date.getHours()
- var minute = date.getMinutes()
- var second = date.getSeconds()
- return [year, month, day].map(formatNumber).join('-') + ' ' + [hour, minute, second].map(formatNumber).join(':')
- }
- function formatNumber(n) {
- n = n.toString()
- return n[1] ? n : '0' + n
- }
- function request(url, data = {}, method = "GET") {
- return new Promise(function (resolve, reject) {
- wx.request({
- url: url,
- data: data,
- method: method,
- header: {
- 'Content-Type': 'application/json',
- 'X-Nideshop-Token': wx.getStorageSync('token')
- },
- success: function (res) {
- console.log("success");
- if (res.statusCode == 200) {
- if (res.data.errno == 401) {
-
- let code = null;
- return login().then((res) => {
- code = res.code;
- return getUserInfo();
- }).then((userInfo) => {
-
- request(api.AuthLoginByWeixin, { code: code, userInfo: userInfo }, 'POST').then(res => {
- if (res.errno === 0) {
-
- wx.setStorageSync('userInfo', res.data.userInfo);
- wx.setStorageSync('token', res.data.token);
-
- resolve(res);
- } else {
- reject(res);
- }
- }).catch((err) => {
- reject(err);
- });
- }).catch((err) => {
- reject(err);
- })
- } else {
- resolve(res.data);
- }
- } else {
- reject(res.errMsg);
- }
- },
- fail: function (err) {
- reject(err)
- console.log("failed")
- }
- })
- });
- }
- function checkSession() {
- return new Promise(function (resolve, reject) {
- wx.checkSession({
- success: function () {
- resolve(true);
- },
- fail: function () {
- reject(false);
- }
- })
- });
- }
- function login() {
- return new Promise(function (resolve, reject) {
- wx.login({
- success: function (res) {
- if (res.code) {
-
- console.log(res)
- resolve(res);
- } else {
- reject(res);
- }
- },
- fail: function (err) {
- reject(err);
- }
- });
- });
- }
- function getUserInfo() {
- return new Promise(function (resolve, reject) {
- wx.getUserInfo({
- withCredentials: true,
- success: function (res) {
- console.log(res)
- resolve(res);
- },
- fail: function (err) {
- reject(err);
- }
- })
- });
- }
- function redirect(url) {
-
- if (false) {
- wx.redirectTo({
- url: '/pages/auth/login/login'
- });
- return false;
- } else {
- wx.redirectTo({
- url: url
- });
- }
- }
- function showErrorToast(msg) {
- wx.showToast({
- title: msg,
- image: '/static/images/icon_error.png'
- })
- }
- module.exports = {
- formatTime,
- request,
- redirect,
- showErrorToast,
- checkSession,
- login,
- getUserInfo,
- }
|