对接支付功能
This commit is contained in:
File diff suppressed because it is too large
Load Diff
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name" : "ShopXO",
|
"name" : "ShopXO",
|
||||||
"appid" : "__UNI__50E3C11",
|
"appid" : "__UNI__F095115",
|
||||||
"description" : "ShopXO开源商城、MIT协议、可商用、可二次开发、满足99%电商运营需求",
|
"description" : "ShopXO开源商城、MIT协议、可商用、可二次开发、满足99%电商运营需求",
|
||||||
"versionName" : "1.0.0",
|
"versionName" : "1.0.0",
|
||||||
"versionCode" : 100,
|
"versionCode" : 100,
|
||||||
@@ -186,19 +186,18 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"__usePrivacyCheck__" : true,
|
"__usePrivacyCheck__" : true,
|
||||||
"plugins" : {
|
"plugins" : {}
|
||||||
// 腾讯地图路线规划插件(需要到小程序后台设置->第三方设置->插件管理里面添加【腾讯位置服务路线规划】插件,教程 https://mp.weixin.qq.com/wxopen/plugindevdoc?appid=wx50b5593e81dd937a)
|
|
||||||
// "routePlan" : {
|
|
||||||
// "version" : "1.0.19",
|
|
||||||
// "provider" : "wx50b5593e81dd937a"
|
|
||||||
// },
|
|
||||||
// 直播(需要到小程序后台设置->第三方设置->插件管理里面添加【小程序直播组件】插件,教程 https://mp.weixin.qq.com/wxopen/pluginbasicprofile?action=intro&appid=wx2b03c6e691cd7370)
|
|
||||||
// "live-player-plugin" : {
|
|
||||||
// "version" : "1.3.5",
|
|
||||||
// "provider" : "wx2b03c6e691cd7370"
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
// 腾讯地图路线规划插件(需要到小程序后台设置->第三方设置->插件管理里面添加【腾讯位置服务路线规划】插件,教程 https://mp.weixin.qq.com/wxopen/plugindevdoc?appid=wx50b5593e81dd937a)
|
||||||
|
// "routePlan" : {
|
||||||
|
// "version" : "1.0.19",
|
||||||
|
// "provider" : "wx50b5593e81dd937a"
|
||||||
|
// },
|
||||||
|
// 直播(需要到小程序后台设置->第三方设置->插件管理里面添加【小程序直播组件】插件,教程 https://mp.weixin.qq.com/wxopen/pluginbasicprofile?action=intro&appid=wx2b03c6e691cd7370)
|
||||||
|
// "live-player-plugin" : {
|
||||||
|
// "version" : "1.3.5",
|
||||||
|
// "provider" : "wx2b03c6e691cd7370"
|
||||||
|
// }
|
||||||
"mp-alipay" : {
|
"mp-alipay" : {
|
||||||
"usingComponents" : true,
|
"usingComponents" : true,
|
||||||
"appid" : "2021001173639600"
|
"appid" : "2021001173639600"
|
||||||
@@ -245,15 +244,36 @@
|
|||||||
},
|
},
|
||||||
"devServer" : {
|
"devServer" : {
|
||||||
"https" : false,
|
"https" : false,
|
||||||
"port" : 8082
|
"port" : 8082,
|
||||||
|
"proxy" : {
|
||||||
|
"/api" : {
|
||||||
|
// "target": "http://192.168.1.43:7777/",
|
||||||
|
"target" : "https://store.sxczgkj.com/",
|
||||||
|
"changeOrigin" : "true",
|
||||||
|
"pathRewrite" : {
|
||||||
|
"^/api" : ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"router" : {
|
"router" : {
|
||||||
"mode" : "hash",
|
"mode" : "history",
|
||||||
"base" : "./"
|
"base" : "/h5_store/"
|
||||||
},
|
},
|
||||||
"title" : "ShopXO",
|
"title" : "czg_shop",
|
||||||
"template" : "template.h5.html"
|
"template" : "template.h5.html"
|
||||||
},
|
},
|
||||||
|
"app" : {
|
||||||
|
"router" : {
|
||||||
|
"mode" : "history"
|
||||||
|
}
|
||||||
|
},
|
||||||
"vueVersion" : "2",
|
"vueVersion" : "2",
|
||||||
"locale" : "auto"
|
"locale" : "auto"
|
||||||
}
|
}
|
||||||
|
// 匹配以 /api 开头的请求
|
||||||
|
// target: 'https://test.invoice.sxczgkj.cn/', // 替换为你的后端 API 域名
|
||||||
|
//192.168.1.43:7777/', // 替换为你的后端 API 域名
|
||||||
|
// 允许跨域
|
||||||
|
// 重写路径,去掉 /api 前缀
|
||||||
|
|
||||||
|
|||||||
21
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/LICENSE
generated
vendored
Normal file
21
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/LICENSE
generated
vendored
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
MIT License
|
||||||
|
|
||||||
|
Copyright (c) 2023 Yanxi
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
36
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/README.md
generated
vendored
Normal file
36
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/README.md
generated
vendored
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
微信官方 js-sdk
|
||||||
|
----
|
||||||
|
|
||||||
|
说明: 仅将官方 js-sdk 发布到 npm,支持 CommonJS,便于 browserify, webpack 等直接使用,支持 TypeScript。
|
||||||
|
|
||||||
|
|
||||||
|
官方 JS 源码: https://res.wx.qq.com/open/js/jweixin-1.6.0.js
|
||||||
|
|
||||||
|
官方使用说明: https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html
|
||||||
|
|
||||||
|
安装:
|
||||||
|
```shell
|
||||||
|
npm install weixin-js-sdk
|
||||||
|
```
|
||||||
|
|
||||||
|
使用:
|
||||||
|
```javascript
|
||||||
|
// commonjs
|
||||||
|
var wx = require('weixin-js-sdk');
|
||||||
|
|
||||||
|
// es module
|
||||||
|
import wx from 'weixin-js-sdk'
|
||||||
|
```
|
||||||
|
|
||||||
|
### Old versions
|
||||||
|
|
||||||
|
* [1.0.0](https://github.com/yanxi123-com/weixin-js-sdk/tree/1.0.0)
|
||||||
|
* [1.2.0](https://github.com/yanxi123-com/weixin-js-sdk/tree/1.2.0)
|
||||||
|
|
||||||
|
### 个人主页
|
||||||
|
|
||||||
|
* [https://yanxi123.com/](https://yanxi123.com/)
|
||||||
|
|
||||||
|
### 感谢
|
||||||
|
|
||||||
|
TypeScript 定义文件来自 [wx-jssdk-ts](https://github.com/zhaoky/wx-jssdk-ts/blob/master/index.d.ts)
|
||||||
601
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/index.d.ts
generated
vendored
Normal file
601
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,601 @@
|
|||||||
|
// Type definitions for weixin jssdk 1.6.0
|
||||||
|
// Project: https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115
|
||||||
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
||||||
|
|
||||||
|
declare namespace wx {
|
||||||
|
type ImageSizeType = "original" | "compressed";
|
||||||
|
type ImageSourceType = "album" | "camera";
|
||||||
|
type VideoSourceType = "album" | "camera";
|
||||||
|
type ApiMethod =
|
||||||
|
| "onMenuShareTimeline"
|
||||||
|
| "onMenuShareAppMessage"
|
||||||
|
| "onMenuShareQQ"
|
||||||
|
| "onMenuShareWeibo"
|
||||||
|
| "onMenuShareQZone"
|
||||||
|
| "updateAppMessageShareData"
|
||||||
|
| "updateTimelineShareData"
|
||||||
|
| "startRecord"
|
||||||
|
| "stopRecord"
|
||||||
|
| "onVoiceRecordEnd"
|
||||||
|
| "playVoice"
|
||||||
|
| "pauseVoice"
|
||||||
|
| "stopVoice"
|
||||||
|
| "onVoicePlayEnd"
|
||||||
|
| "uploadVoice"
|
||||||
|
| "downloadVoice"
|
||||||
|
| "chooseImage"
|
||||||
|
| "previewImage"
|
||||||
|
| "uploadImage"
|
||||||
|
| "downloadImage"
|
||||||
|
| "translateVoice"
|
||||||
|
| "getNetworkType"
|
||||||
|
| "openLocation"
|
||||||
|
| "getLocation"
|
||||||
|
| "hideOptionMenu"
|
||||||
|
| "showOptionMenu"
|
||||||
|
| "hideMenuItems"
|
||||||
|
| "showMenuItems"
|
||||||
|
| "hideAllNonBaseMenuItem"
|
||||||
|
| "showAllNonBaseMenuItem"
|
||||||
|
| "closeWindow"
|
||||||
|
| "scanQRCode"
|
||||||
|
| "chooseWXPay"
|
||||||
|
| "openProductSpecificView"
|
||||||
|
| "addCard"
|
||||||
|
| "chooseCard"
|
||||||
|
| "openCard";
|
||||||
|
// 所有JS接口列表
|
||||||
|
type jsApiList = ApiMethod[];
|
||||||
|
|
||||||
|
// 开放标签列表
|
||||||
|
// https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_Open_Tag.html
|
||||||
|
type openTag = "wx-open-launch-weapp" | "wx-open-launch-app" | "wx-open-subscribe" | "wx-open-audio"
|
||||||
|
type openTagList = openTag[];
|
||||||
|
|
||||||
|
// 所有菜单项列表
|
||||||
|
// 基本类
|
||||||
|
type menuBase =
|
||||||
|
| "menuItem:exposeArticle" // 举报
|
||||||
|
| "menuItem:setFont" // 调整字体
|
||||||
|
| "menuItem:dayMode" // 日间模式
|
||||||
|
| "menuItem:nightMode" // 夜间模式
|
||||||
|
| "menuItem:refresh" // 刷新
|
||||||
|
| "menuItem:profile" // 查看公众号(已添加)
|
||||||
|
| "menuItem:addContact"; // 查看公众号(未添加)
|
||||||
|
// 传播类
|
||||||
|
type menuShare =
|
||||||
|
| "menuItem:share:appMessage" // 发送给朋友
|
||||||
|
| "menuItem:share:timeline" // 分享到朋友圈
|
||||||
|
| "menuItem:share:qq" // 分享到QQ
|
||||||
|
| "menuItem:share:weiboApp" // 分享到Weibo
|
||||||
|
| "menuItem:favorite" // 收藏
|
||||||
|
| "menuItem:share:facebook" // 分享到FB
|
||||||
|
| "menuItem:share:QZone"; // 分享到 QQ 空间
|
||||||
|
|
||||||
|
// 保护类
|
||||||
|
type menuProtected =
|
||||||
|
| "menuItem:editTag" // 编辑标签
|
||||||
|
| "menuItem:delete" // 删除
|
||||||
|
| "menuItem:copyUrl" // 复制链接
|
||||||
|
| "menuItem:originPage" // 原网页
|
||||||
|
| "menuItem:readMode" // 阅读模式
|
||||||
|
| "menuItem:openWithQQBrowser" // 在QQ浏览器中打开
|
||||||
|
| "menuItem:openWithSafari" // 在Safari中打开
|
||||||
|
| "menuItem:share:email" // 邮件
|
||||||
|
| "menuItem:share:brand"; // 一些特殊公众号
|
||||||
|
|
||||||
|
type menuList = Array<menuBase | menuProtected | menuShare>;
|
||||||
|
|
||||||
|
function config(conf: {
|
||||||
|
debug?: boolean; // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
|
||||||
|
appId: string; // 必填,公众号的唯一标识
|
||||||
|
timestamp: number; // 必填,生成签名的时间戳
|
||||||
|
nonceStr: string; // 必填,生成签名的随机串
|
||||||
|
signature: string; // 必填,签名,见附录1
|
||||||
|
jsApiList?: jsApiList; // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
|
||||||
|
openTagList?: openTagList;
|
||||||
|
}): void;
|
||||||
|
|
||||||
|
interface Resouce {
|
||||||
|
localId: string;
|
||||||
|
}
|
||||||
|
interface BaseParams {
|
||||||
|
success?(...args: any[]): void;
|
||||||
|
/** 接口调用失败的回调函数 */
|
||||||
|
fail?(...args: any[]): void;
|
||||||
|
/** 接口取消调用的回调函数 */
|
||||||
|
cancel?(...args: any[]): void;
|
||||||
|
/** 接口调用结束的回调函数(调用成功、失败都会执行) */
|
||||||
|
complete?(...args: any[]): void;
|
||||||
|
}
|
||||||
|
function ready(fn: () => void): void;
|
||||||
|
function error(fn: (err: { errMsg: string }) => void): void;
|
||||||
|
|
||||||
|
interface IcheckJsApi extends BaseParams {
|
||||||
|
jsApiList: jsApiList; // 需要检测的JS接口列表,所有JS接口列表见附录2,
|
||||||
|
// 以键值对的形式返回,可用的api值true,不可用为false
|
||||||
|
// 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"}
|
||||||
|
success(res: {
|
||||||
|
checkResult: { [api: string]: boolean };
|
||||||
|
errMsg: string;
|
||||||
|
}): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 判断当前客户端版本是否支持指定JS接口
|
||||||
|
* 备注:checkJsApi接口是客户端6.0.2新引入的一个预留接口,第一期开放的接口均可不使用checkJsApi来检测。
|
||||||
|
*/
|
||||||
|
function checkJsApi(params: IcheckJsApi): void;
|
||||||
|
|
||||||
|
interface IonMenuShareTimeline extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/*=============================基础接口================================*/
|
||||||
|
/**
|
||||||
|
* 获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareTimeline(params: IonMenuShareTimeline): void;
|
||||||
|
|
||||||
|
interface IonMenuShareAppMessage extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
type?: "music" | "video或link" | "link"; // 分享类型,music、video或link,不填默认为link
|
||||||
|
dataUrl?: string; // 如果type是music或video,则要提供数据链接,默认为空
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享给朋友”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareAppMessage(params: IonMenuShareAppMessage): void;
|
||||||
|
|
||||||
|
interface IonMenuShareQQ extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到QQ”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareQQ(params: IonMenuShareQQ): void;
|
||||||
|
|
||||||
|
interface IonMenuShareWeibo extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareWeibo(params: IonMenuShareWeibo): void;
|
||||||
|
|
||||||
|
interface IonMenuShareQZone extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到QQ空间”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareQZone(params: IonMenuShareQZone): void;
|
||||||
|
|
||||||
|
interface IupdateAppMessageShareData extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享给朋友”及“分享到QQ”按钮点击状态及自定义分享内容接口(新)
|
||||||
|
*/
|
||||||
|
function updateAppMessageShareData(params: IupdateAppMessageShareData): void;
|
||||||
|
|
||||||
|
interface IupdateTimelineShareData extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到朋友圈”及“分享到QQ空间”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function updateTimelineShareData(params: IupdateTimelineShareData): void;
|
||||||
|
/*=============================基础接口================================*/
|
||||||
|
|
||||||
|
/*=============================图像接口================================*/
|
||||||
|
interface IchooseImage extends BaseParams {
|
||||||
|
/** 最多可以选择的图片张数,默认9 */
|
||||||
|
count?: number;
|
||||||
|
/** original 原图,compressed 压缩图,默认二者都有 */
|
||||||
|
sizeType?: ImageSizeType[];
|
||||||
|
/** album 从相册选图,camera 使用相机,默认二者都有 */
|
||||||
|
sourceType?: ImageSourceType[];
|
||||||
|
/** 成功则返回图片的本地文件路径列表 tempFilePaths */
|
||||||
|
success(res: {
|
||||||
|
sourceType: string; // weixin album camera
|
||||||
|
localIds: string[];
|
||||||
|
errMsg: string;
|
||||||
|
}): void;
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 从本地相册选择图片或使用相机拍照。
|
||||||
|
*/
|
||||||
|
function chooseImage(params: IchooseImage): void;
|
||||||
|
|
||||||
|
interface IpreviewImage extends BaseParams {
|
||||||
|
current: string; // 当前显示图片的http链接
|
||||||
|
urls: string[]; // 需要预览的图片http链接列表
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 预览图片接口
|
||||||
|
*/
|
||||||
|
function previewImage(params: IpreviewImage): void;
|
||||||
|
|
||||||
|
interface IuploadResource extends BaseParams {
|
||||||
|
localId: string; // 需要上传的图片的本地ID,由chooseImage接口获得
|
||||||
|
isShowProgressTips: number; // 默认为1,显示进度提示
|
||||||
|
// 返回图片的服务器端ID
|
||||||
|
success(res: { serverId: string }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 上传图片接口
|
||||||
|
*/
|
||||||
|
function uploadImage(params: IuploadResource): void;
|
||||||
|
|
||||||
|
interface IdownloadResource extends BaseParams {
|
||||||
|
serverId: string; // 需要下载的图片的服务器端ID,由uploadImage接口获得
|
||||||
|
isShowProgressTips: number; // 默认为1,显示进度提示
|
||||||
|
// 返回图片下载后的本地ID
|
||||||
|
success(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 下载图片接口
|
||||||
|
*/
|
||||||
|
function downloadImage(params: IdownloadResource): void;
|
||||||
|
|
||||||
|
interface IgetLocalImgData extends BaseParams {
|
||||||
|
localId: string; // 图片的localID
|
||||||
|
// localData是图片的base64数据,可以用img标签显示
|
||||||
|
success(res: { localData: string }): void;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取本地图片接口
|
||||||
|
*/
|
||||||
|
function getLocalImgData(params: IgetLocalImgData): void;
|
||||||
|
/*=============================图像接口================================*/
|
||||||
|
/*=============================音频接口================================*/
|
||||||
|
/**
|
||||||
|
* 开始录音接口
|
||||||
|
*/
|
||||||
|
function startRecord(): void;
|
||||||
|
|
||||||
|
interface IstopRecord extends BaseParams {
|
||||||
|
success(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 停止录音接口
|
||||||
|
*/
|
||||||
|
function stopRecord(params: IstopRecord): void;
|
||||||
|
|
||||||
|
interface IonVoiceRecordEnd extends BaseParams {
|
||||||
|
// 录音时间超过一分钟没有停止的时候会执行 complete 回调
|
||||||
|
complete(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 监听录音自动停止接口
|
||||||
|
*/
|
||||||
|
function onVoiceRecordEnd(params: IonVoiceRecordEnd): void;
|
||||||
|
|
||||||
|
interface IplaypausestopVoice extends BaseParams {
|
||||||
|
localId: string; // 需要播放的音频的本地ID,由stopRecord接口获得
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 播放语音接口
|
||||||
|
*/
|
||||||
|
function playVoice(params: IplaypausestopVoice): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 暂停播放接口
|
||||||
|
*/
|
||||||
|
function pauseVoice(params: IplaypausestopVoice): void;
|
||||||
|
/**
|
||||||
|
* 停止播放接口
|
||||||
|
*/
|
||||||
|
function stopVoice(params: IplaypausestopVoice): void;
|
||||||
|
|
||||||
|
interface IonVoicePlayEnd extends BaseParams {
|
||||||
|
success(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 监听语音播放完毕接口
|
||||||
|
*/
|
||||||
|
function onVoicePlayEnd(params: IonVoicePlayEnd): void;
|
||||||
|
/**
|
||||||
|
* 上传语音接口
|
||||||
|
* 备注:上传语音有效期3天,可用微信多媒体接口下载语音到自己的服务器
|
||||||
|
* ,此处获得的 serverId 即 media_id,参考文档
|
||||||
|
* ../12 / 58bfcfabbd501c7cd77c19bd9cfa8354.html
|
||||||
|
* 目前多媒体文件下载接口的频率限制为10000次/ 天,
|
||||||
|
* 如需要调高频率,请邮件weixin - open@qq.com,
|
||||||
|
* 邮件主题为【申请多媒体接口调用量】,请对你的项目进行简单描述,
|
||||||
|
* 附上产品体验链接,并对用户量和使用量进行说明。
|
||||||
|
*/
|
||||||
|
function uploadVoice(params: IuploadResource): void;
|
||||||
|
/**
|
||||||
|
* 下载语音接口
|
||||||
|
*/
|
||||||
|
function downloadVoice(params: IdownloadResource): void;
|
||||||
|
/*=============================音频接口================================*/
|
||||||
|
/*=============================智能接口================================*/
|
||||||
|
|
||||||
|
interface ItranslateVoice extends BaseParams {
|
||||||
|
localId: string; // 需要识别的音频的本地Id,由录音相关接口获得
|
||||||
|
isShowProgressTips: number; // 默认为1,显示进度提示
|
||||||
|
success(res: { translateResult: string }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 识别音频并返回识别结果接口
|
||||||
|
*/
|
||||||
|
function translateVoice(params: ItranslateVoice): void;
|
||||||
|
|
||||||
|
/*=============================智能接口================================*/
|
||||||
|
|
||||||
|
/*=============================设备信息================================*/
|
||||||
|
type networkType = "2g" | "3g" | "4g" | "wifi";
|
||||||
|
interface IgetNetworkType extends BaseParams {
|
||||||
|
success(res: { networkType: networkType }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取网络状态接口
|
||||||
|
*/
|
||||||
|
function getNetworkType(params: IgetNetworkType): void;
|
||||||
|
/*=============================设备信息================================*/
|
||||||
|
|
||||||
|
/*=============================地理位置================================*/
|
||||||
|
interface IopenLocation extends BaseParams {
|
||||||
|
latitude: number; // 纬度,浮点数,范围为90 ~ -90
|
||||||
|
longitude: number; // 经度,浮点数,范围为180 ~ -180。
|
||||||
|
name: string; // 位置名
|
||||||
|
address: string; // 地址详情说明
|
||||||
|
scale: number; // 地图缩放级别,整形值,范围从1~28。默认为最大
|
||||||
|
infoUrl: string; // 在查看位置界面底部显示的超链接,可点击跳转
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 使用微信内置地图查看位置接口
|
||||||
|
*/
|
||||||
|
function openLocation(params: IopenLocation): void;
|
||||||
|
|
||||||
|
interface IgetLocation extends BaseParams {
|
||||||
|
type: "wgs84" | "gcj02"; // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
|
||||||
|
success(res: {
|
||||||
|
latitude: number; // 纬度,浮点数,范围为90 ~ -90
|
||||||
|
longitude: number; // 经度,浮点数,范围为180 ~ -180。
|
||||||
|
speed: number; // 速度,以米/每秒计
|
||||||
|
accuracy: number; // 位置精度
|
||||||
|
}): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取地理位置接口
|
||||||
|
*/
|
||||||
|
function getLocation(params: IgetLocation): void;
|
||||||
|
/*=============================地理位置================================*/
|
||||||
|
/*=============================摇一摇周边================================*/
|
||||||
|
interface IstartSearchBeacons extends BaseParams {
|
||||||
|
ticket: string; // 摇周边的业务ticket, 系统自动添加在摇出来的页面链接后面
|
||||||
|
// 开启查找完成后的回调函数
|
||||||
|
complete(argv: any): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 开启查找周边ibeacon设备接口
|
||||||
|
* 备注:如需接入摇一摇周边功能,请参考:申请开通摇一摇周边
|
||||||
|
*/
|
||||||
|
function startSearchBeacons(params: IstartSearchBeacons): void;
|
||||||
|
|
||||||
|
interface IstopSearchBeacons extends BaseParams {
|
||||||
|
// 关闭查找完成后的回调函数
|
||||||
|
complete(res: any): void;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 关闭查找周边ibeacon设备接口
|
||||||
|
*/
|
||||||
|
function stopSearchBeacons(params: IstopSearchBeacons): void;
|
||||||
|
|
||||||
|
interface IonSearchBeacons extends BaseParams {
|
||||||
|
// 回调函数,可以数组形式取得该商家注册的在周边的相关设备列表
|
||||||
|
complete(argv: any): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 监听周边ibeacon设备接口
|
||||||
|
*/
|
||||||
|
function onSearchBeacons(params: IonSearchBeacons): void;
|
||||||
|
/*=============================摇一摇周边================================*/
|
||||||
|
/*=============================界面操作================================*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 隐藏右上角菜单接口
|
||||||
|
*/
|
||||||
|
function hideOptionMenu(): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 显示右上角菜单接口
|
||||||
|
*/
|
||||||
|
function showOptionMenu(): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 关闭当前网页窗口接口
|
||||||
|
*/
|
||||||
|
function closeWindow(): void;
|
||||||
|
|
||||||
|
interface IhideMenuItems extends BaseParams {
|
||||||
|
menuList: Array<menuProtected | menuShare>; // 要隐藏的菜单项,只能隐藏“传播类”和“保护类”按钮,所有menu项见附录3
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 批量隐藏功能按钮接口
|
||||||
|
*/
|
||||||
|
function hideMenuItems(params: IhideMenuItems): void;
|
||||||
|
|
||||||
|
interface IshowMenuItems extends BaseParams {
|
||||||
|
menuList: menuList; // 要显示的菜单项,所有menu项见附录3
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 批量显示功能按钮接口
|
||||||
|
*/
|
||||||
|
function showMenuItems(params: IshowMenuItems): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 隐藏所有非基础按钮接口
|
||||||
|
* “基本类”按钮详见附录3
|
||||||
|
*/
|
||||||
|
function hideAllNonBaseMenuItem(): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 显示所有功能按钮接口
|
||||||
|
*/
|
||||||
|
function showAllNonBaseMenuItem(): void;
|
||||||
|
/*=============================界面操作================================*/
|
||||||
|
/*=============================微信扫一扫================================*/
|
||||||
|
|
||||||
|
type scanType = "qrCode" | "barCode";
|
||||||
|
|
||||||
|
interface IscanQRCode extends BaseParams {
|
||||||
|
needResult: 0 | 1; // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
|
||||||
|
scanType: scanType[]; // 可以指定扫二维码还是一维码,默认二者都有
|
||||||
|
// 当needResult 为 1 时,扫码返回的结果
|
||||||
|
success(res: { resultStr: string }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 调起微信扫一扫接口
|
||||||
|
*/
|
||||||
|
function scanQRCode(params: IscanQRCode): void;
|
||||||
|
/*=============================微信扫一扫================================*/
|
||||||
|
/*=============================微信小店================================*/
|
||||||
|
|
||||||
|
interface IopenProductSpecificView extends BaseParams {
|
||||||
|
productId: string; // 商品id
|
||||||
|
viewType: "0" | "1" | "2"; // 0.默认值,普通商品详情页1.扫一扫商品详情页2.小店商品详情页
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 跳转微信商品页接口
|
||||||
|
*/
|
||||||
|
function openProductSpecificView(params: IopenProductSpecificView): void;
|
||||||
|
/*=============================微信卡券================================*/
|
||||||
|
|
||||||
|
interface IchooseCard extends BaseParams {
|
||||||
|
shopId: string; // 门店Id
|
||||||
|
cardType: string; // 卡券类型
|
||||||
|
cardId: string; // 卡券Id
|
||||||
|
timestamp: number; // 卡券签名时间戳
|
||||||
|
nonceStr: string; // 卡券签名随机串
|
||||||
|
signType: string; // 签名方式,默认'SHA1'
|
||||||
|
cardSign: string; // 卡券签名
|
||||||
|
success(res: { cardList: string[] }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 拉取适用卡券列表并获取用户选择信息
|
||||||
|
*/
|
||||||
|
function chooseCard(params: IchooseCard): void;
|
||||||
|
|
||||||
|
interface IaddCard extends BaseParams {
|
||||||
|
cardList: Array<{
|
||||||
|
cardId: string;
|
||||||
|
cardExt: string;
|
||||||
|
}>; // 需要添加的卡券列表
|
||||||
|
success(res: { cardList: string[] }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 批量添加卡券接口
|
||||||
|
*/
|
||||||
|
function addCard(): void;
|
||||||
|
|
||||||
|
interface IopenCard extends BaseParams {
|
||||||
|
cardList: Array<{
|
||||||
|
cardId: string;
|
||||||
|
code: string;
|
||||||
|
}>; // 需要打开的卡券列表
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 查看微信卡包中的卡券接口
|
||||||
|
*/
|
||||||
|
function openCard(params: IopenCard): void;
|
||||||
|
|
||||||
|
interface IconsumeAndShareCard extends BaseParams {
|
||||||
|
cardId: string;
|
||||||
|
code: string;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 核销后再次赠送卡券接口
|
||||||
|
*/
|
||||||
|
function consumeAndShareCard(params: IconsumeAndShareCard): void;
|
||||||
|
/*=============================微信卡券================================*/
|
||||||
|
/*=============================微信支付================================*/
|
||||||
|
|
||||||
|
interface IchooseWXPay extends BaseParams {
|
||||||
|
timestamp: number; // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
|
||||||
|
nonceStr: string; // 支付签名随机串,不长于 32 位
|
||||||
|
package: string; // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
|
||||||
|
signType: string; // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
|
||||||
|
paySign: string; // 支付签名
|
||||||
|
// 支付成功后的回调函数
|
||||||
|
success(res: any): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 发起一个微信支付请求
|
||||||
|
*/
|
||||||
|
function chooseWXPay(params: IchooseWXPay): void;
|
||||||
|
/*=============================微信支付================================*/
|
||||||
|
/*=============================微信小程序==============================*/
|
||||||
|
interface miniProgramMethodsParams extends BaseParams {
|
||||||
|
url: string;
|
||||||
|
}
|
||||||
|
interface miniProgramMethods {
|
||||||
|
navigateTo(params: miniProgramMethodsParams): void;
|
||||||
|
navigateBack(params: miniProgramMethodsParams): void;
|
||||||
|
switchTab(params: miniProgramMethodsParams): void;
|
||||||
|
reLaunch(params: miniProgramMethodsParams): void;
|
||||||
|
redirectTo(params: miniProgramMethodsParams): void;
|
||||||
|
postMessage(params: { data: any }): void;
|
||||||
|
getEnv(fn: (res: any) => void): void;
|
||||||
|
}
|
||||||
|
const miniProgram: miniProgramMethods;
|
||||||
|
/*=============================微信小程序==============================*/
|
||||||
|
}
|
||||||
|
declare function wx(): void;
|
||||||
|
/*=============================微信内全局变量==============================*/
|
||||||
|
declare global {
|
||||||
|
interface Window {
|
||||||
|
WeixinJSBridge: any;
|
||||||
|
__wxjs_environment: any;
|
||||||
|
}
|
||||||
|
const WeixinJSBridge: any;
|
||||||
|
}
|
||||||
|
export default wx;
|
||||||
891
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/index.js
generated
vendored
Normal file
891
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/index.js
generated
vendored
Normal file
@@ -0,0 +1,891 @@
|
|||||||
|
!(function (e, n) {
|
||||||
|
module.exports = n(e);
|
||||||
|
})(typeof window === "object" && window, function (r, e) {
|
||||||
|
if (!r) {
|
||||||
|
console.warn("can't use weixin-js-sdk in server side");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var a, c, n, i, t, o, s, d, l, u, p, f, m, g, h, S, y, I, v, _, w, T;
|
||||||
|
if (!r.jWeixin)
|
||||||
|
return (
|
||||||
|
(a = {
|
||||||
|
config: "preVerifyJSAPI",
|
||||||
|
onMenuShareTimeline: "menu:share:timeline",
|
||||||
|
onMenuShareAppMessage: "menu:share:appmessage",
|
||||||
|
onMenuShareQQ: "menu:share:qq",
|
||||||
|
onMenuShareWeibo: "menu:share:weiboApp",
|
||||||
|
onMenuShareQZone: "menu:share:QZone",
|
||||||
|
previewImage: "imagePreview",
|
||||||
|
getLocation: "geoLocation",
|
||||||
|
openProductSpecificView: "openProductViewWithPid",
|
||||||
|
addCard: "batchAddCard",
|
||||||
|
openCard: "batchViewCard",
|
||||||
|
chooseWXPay: "getBrandWCPayRequest",
|
||||||
|
openEnterpriseRedPacket: "getRecevieBizHongBaoRequest",
|
||||||
|
startSearchBeacons: "startMonitoringBeacons",
|
||||||
|
stopSearchBeacons: "stopMonitoringBeacons",
|
||||||
|
onSearchBeacons: "onBeaconsInRange",
|
||||||
|
consumeAndShareCard: "consumedShareCard",
|
||||||
|
openAddress: "editAddress",
|
||||||
|
}),
|
||||||
|
(c = (function () {
|
||||||
|
var e,
|
||||||
|
n = {};
|
||||||
|
for (e in a) n[a[e]] = e;
|
||||||
|
return n;
|
||||||
|
})()),
|
||||||
|
(n = r.document),
|
||||||
|
(i = n.title),
|
||||||
|
(t = navigator.userAgent.toLowerCase()),
|
||||||
|
(f = navigator.platform.toLowerCase()),
|
||||||
|
(o = !(!f.match("mac") && !f.match("win"))),
|
||||||
|
(s = -1 != t.indexOf("wxdebugger")),
|
||||||
|
(d = -1 != t.indexOf("micromessenger")),
|
||||||
|
(l = -1 != t.indexOf("android")),
|
||||||
|
(u = -1 != t.indexOf("iphone") || -1 != t.indexOf("ipad")),
|
||||||
|
(p = (f =
|
||||||
|
t.match(/micromessenger\/(\d+\.\d+\.\d+)/) ||
|
||||||
|
t.match(/micromessenger\/(\d+\.\d+)/))
|
||||||
|
? f[1]
|
||||||
|
: ""),
|
||||||
|
(m = {
|
||||||
|
initStartTime: L(),
|
||||||
|
initEndTime: 0,
|
||||||
|
preVerifyStartTime: 0,
|
||||||
|
preVerifyEndTime: 0,
|
||||||
|
}),
|
||||||
|
(g = {
|
||||||
|
version: 1,
|
||||||
|
appId: "",
|
||||||
|
initTime: 0,
|
||||||
|
preVerifyTime: 0,
|
||||||
|
networkType: "",
|
||||||
|
isPreVerifyOk: 1,
|
||||||
|
systemType: u ? 1 : l ? 2 : -1,
|
||||||
|
clientVersion: p,
|
||||||
|
url: encodeURIComponent(location.href),
|
||||||
|
}),
|
||||||
|
(h = {}),
|
||||||
|
(S = { _completes: [] }),
|
||||||
|
(y = { state: 0, data: {} }),
|
||||||
|
O(function () {
|
||||||
|
m.initEndTime = L();
|
||||||
|
}),
|
||||||
|
(I = !1),
|
||||||
|
(v = []),
|
||||||
|
(_ = {
|
||||||
|
config: function (e) {
|
||||||
|
C("config", (h = e));
|
||||||
|
var o = !1 !== h.check;
|
||||||
|
O(function () {
|
||||||
|
if (o)
|
||||||
|
k(
|
||||||
|
a.config,
|
||||||
|
{
|
||||||
|
verifyJsApiList: A(h.jsApiList),
|
||||||
|
verifyOpenTagList: A(h.openTagList),
|
||||||
|
},
|
||||||
|
((S._complete = function (e) {
|
||||||
|
(m.preVerifyEndTime = L()), (y.state = 1), (y.data = e);
|
||||||
|
}),
|
||||||
|
(S.success = function (e) {
|
||||||
|
g.isPreVerifyOk = 0;
|
||||||
|
}),
|
||||||
|
(S.fail = function (e) {
|
||||||
|
S._fail ? S._fail(e) : (y.state = -1);
|
||||||
|
}),
|
||||||
|
(t = S._completes).push(function () {
|
||||||
|
B();
|
||||||
|
}),
|
||||||
|
(S.complete = function (e) {
|
||||||
|
for (var n = 0, i = t.length; n < i; ++n) t[n]();
|
||||||
|
S._completes = [];
|
||||||
|
}),
|
||||||
|
S)
|
||||||
|
),
|
||||||
|
(m.preVerifyStartTime = L());
|
||||||
|
else {
|
||||||
|
y.state = 1;
|
||||||
|
for (var e = S._completes, n = 0, i = e.length; n < i; ++n)
|
||||||
|
e[n]();
|
||||||
|
S._completes = [];
|
||||||
|
}
|
||||||
|
var t;
|
||||||
|
}),
|
||||||
|
_.invoke ||
|
||||||
|
((_.invoke = function (e, n, i) {
|
||||||
|
r.WeixinJSBridge && WeixinJSBridge.invoke(e, P(n), i);
|
||||||
|
}),
|
||||||
|
(_.on = function (e, n) {
|
||||||
|
r.WeixinJSBridge && WeixinJSBridge.on(e, n);
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
ready: function (e) {
|
||||||
|
(0 != y.state || (S._completes.push(e), !d && h.debug)) && e();
|
||||||
|
},
|
||||||
|
error: function (e) {
|
||||||
|
p < "6.0.2" || (-1 == y.state ? e(y.data) : (S._fail = e));
|
||||||
|
},
|
||||||
|
checkJsApi: function (e) {
|
||||||
|
k(
|
||||||
|
"checkJsApi",
|
||||||
|
{ jsApiList: A(e.jsApiList) },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
l && (i = e.checkResult) && (e.checkResult = JSON.parse(i));
|
||||||
|
var n,
|
||||||
|
i = e,
|
||||||
|
t = i.checkResult;
|
||||||
|
for (n in t) {
|
||||||
|
var o = c[n];
|
||||||
|
o && ((t[o] = t[n]), delete t[n]);
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareTimeline: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareTimeline,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareTimeline",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.title || i,
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
type: e.type || "link",
|
||||||
|
data_url: e.dataUrl || "",
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareAppMessage: function (n) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareAppMessage,
|
||||||
|
{
|
||||||
|
complete: function (e) {
|
||||||
|
"favorite" === e.scene
|
||||||
|
? k("sendAppMessage", {
|
||||||
|
title: n.title || i,
|
||||||
|
desc: n.desc || "",
|
||||||
|
link: n.link || location.href,
|
||||||
|
img_url: n.imgUrl || "",
|
||||||
|
type: n.type || "link",
|
||||||
|
data_url: n.dataUrl || "",
|
||||||
|
})
|
||||||
|
: k(
|
||||||
|
"sendAppMessage",
|
||||||
|
{
|
||||||
|
title: n.title || i,
|
||||||
|
desc: n.desc || "",
|
||||||
|
link: n.link || location.href,
|
||||||
|
img_url: n.imgUrl || "",
|
||||||
|
type: n.type || "link",
|
||||||
|
data_url: n.dataUrl || "",
|
||||||
|
},
|
||||||
|
n
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
n
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareQQ: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareQQ,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareQQ",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.desc || "",
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareWeibo: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareWeibo,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareWeiboApp",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.desc || "",
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareQZone: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareQZone,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareQZone",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.desc || "",
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
updateTimelineShareData: function (e) {
|
||||||
|
k(
|
||||||
|
"updateTimelineShareData",
|
||||||
|
{ title: e.title, link: e.link, imgUrl: e.imgUrl },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
updateAppMessageShareData: function (e) {
|
||||||
|
k(
|
||||||
|
"updateAppMessageShareData",
|
||||||
|
{ title: e.title, desc: e.desc, link: e.link, imgUrl: e.imgUrl },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
startRecord: function (e) {
|
||||||
|
k("startRecord", {}, e);
|
||||||
|
},
|
||||||
|
stopRecord: function (e) {
|
||||||
|
k("stopRecord", {}, e);
|
||||||
|
},
|
||||||
|
onVoiceRecordEnd: function (e) {
|
||||||
|
M("onVoiceRecordEnd", e);
|
||||||
|
},
|
||||||
|
playVoice: function (e) {
|
||||||
|
k("playVoice", { localId: e.localId }, e);
|
||||||
|
},
|
||||||
|
pauseVoice: function (e) {
|
||||||
|
k("pauseVoice", { localId: e.localId }, e);
|
||||||
|
},
|
||||||
|
stopVoice: function (e) {
|
||||||
|
k("stopVoice", { localId: e.localId }, e);
|
||||||
|
},
|
||||||
|
onVoicePlayEnd: function (e) {
|
||||||
|
M("onVoicePlayEnd", e);
|
||||||
|
},
|
||||||
|
uploadVoice: function (e) {
|
||||||
|
k(
|
||||||
|
"uploadVoice",
|
||||||
|
{
|
||||||
|
localId: e.localId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
downloadVoice: function (e) {
|
||||||
|
k(
|
||||||
|
"downloadVoice",
|
||||||
|
{
|
||||||
|
serverId: e.serverId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
translateVoice: function (e) {
|
||||||
|
k(
|
||||||
|
"translateVoice",
|
||||||
|
{
|
||||||
|
localId: e.localId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
chooseImage: function (e) {
|
||||||
|
k(
|
||||||
|
"chooseImage",
|
||||||
|
{
|
||||||
|
scene: "1|2",
|
||||||
|
count: e.count || 9,
|
||||||
|
sizeType: e.sizeType || ["original", "compressed"],
|
||||||
|
sourceType: e.sourceType || ["album", "camera"],
|
||||||
|
},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
if (l) {
|
||||||
|
var n = e.localIds;
|
||||||
|
try {
|
||||||
|
n && (e.localIds = JSON.parse(n));
|
||||||
|
} catch (e) {}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
getLocation: function (e) {
|
||||||
|
(e = e || {}),
|
||||||
|
k(
|
||||||
|
a.getLocation,
|
||||||
|
{ type: e.type || "wgs84" },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
delete e.type;
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
previewImage: function (e) {
|
||||||
|
k(a.previewImage, { current: e.current, urls: e.urls }, e);
|
||||||
|
},
|
||||||
|
uploadImage: function (e) {
|
||||||
|
k(
|
||||||
|
"uploadImage",
|
||||||
|
{
|
||||||
|
localId: e.localId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
downloadImage: function (e) {
|
||||||
|
k(
|
||||||
|
"downloadImage",
|
||||||
|
{
|
||||||
|
serverId: e.serverId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
getLocalImgData: function (e) {
|
||||||
|
!1 === I
|
||||||
|
? ((I = !0),
|
||||||
|
k(
|
||||||
|
"getLocalImgData",
|
||||||
|
{ localId: e.localId },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
var n;
|
||||||
|
(I = !1),
|
||||||
|
0 < v.length && ((n = v.shift()), wx.getLocalImgData(n));
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
))
|
||||||
|
: v.push(e);
|
||||||
|
},
|
||||||
|
getNetworkType: function (e) {
|
||||||
|
k(
|
||||||
|
"getNetworkType",
|
||||||
|
{},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
var n = e,
|
||||||
|
e = n.errMsg,
|
||||||
|
i = ((n.errMsg = "getNetworkType:ok"), n.subtype);
|
||||||
|
if ((delete n.subtype, i)) n.networkType = i;
|
||||||
|
else {
|
||||||
|
var i = e.indexOf(":"),
|
||||||
|
t = e.substring(i + 1);
|
||||||
|
switch (t) {
|
||||||
|
case "wifi":
|
||||||
|
case "edge":
|
||||||
|
case "wwan":
|
||||||
|
n.networkType = t;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
n.errMsg = "getNetworkType:fail";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openLocation: function (e) {
|
||||||
|
k(
|
||||||
|
"openLocation",
|
||||||
|
{
|
||||||
|
latitude: e.latitude,
|
||||||
|
longitude: e.longitude,
|
||||||
|
name: e.name || "",
|
||||||
|
address: e.address || "",
|
||||||
|
scale: e.scale || 28,
|
||||||
|
infoUrl: e.infoUrl || "",
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
hideOptionMenu: function (e) {
|
||||||
|
k("hideOptionMenu", {}, e);
|
||||||
|
},
|
||||||
|
showOptionMenu: function (e) {
|
||||||
|
k("showOptionMenu", {}, e);
|
||||||
|
},
|
||||||
|
closeWindow: function (e) {
|
||||||
|
k("closeWindow", {}, (e = e || {}));
|
||||||
|
},
|
||||||
|
hideMenuItems: function (e) {
|
||||||
|
k("hideMenuItems", { menuList: e.menuList }, e);
|
||||||
|
},
|
||||||
|
showMenuItems: function (e) {
|
||||||
|
k("showMenuItems", { menuList: e.menuList }, e);
|
||||||
|
},
|
||||||
|
hideAllNonBaseMenuItem: function (e) {
|
||||||
|
k("hideAllNonBaseMenuItem", {}, e);
|
||||||
|
},
|
||||||
|
showAllNonBaseMenuItem: function (e) {
|
||||||
|
k("showAllNonBaseMenuItem", {}, e);
|
||||||
|
},
|
||||||
|
scanQRCode: function (e) {
|
||||||
|
k(
|
||||||
|
"scanQRCode",
|
||||||
|
{
|
||||||
|
needResult: (e = e || {}).needResult || 0,
|
||||||
|
scanType: e.scanType || ["qrCode", "barCode"],
|
||||||
|
},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
var n;
|
||||||
|
u &&
|
||||||
|
(n = e.resultStr) &&
|
||||||
|
((n = JSON.parse(n)),
|
||||||
|
(e.resultStr = n && n.scan_code && n.scan_code.scan_result));
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openAddress: function (e) {
|
||||||
|
k(
|
||||||
|
a.openAddress,
|
||||||
|
{},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
((e = e).postalCode = e.addressPostalCode),
|
||||||
|
delete e.addressPostalCode,
|
||||||
|
(e.provinceName = e.proviceFirstStageName),
|
||||||
|
delete e.proviceFirstStageName,
|
||||||
|
(e.cityName = e.addressCitySecondStageName),
|
||||||
|
delete e.addressCitySecondStageName,
|
||||||
|
(e.countryName = e.addressCountiesThirdStageName),
|
||||||
|
delete e.addressCountiesThirdStageName,
|
||||||
|
(e.detailInfo = e.addressDetailInfo),
|
||||||
|
delete e.addressDetailInfo;
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openProductSpecificView: function (e) {
|
||||||
|
k(
|
||||||
|
a.openProductSpecificView,
|
||||||
|
{
|
||||||
|
pid: e.productId,
|
||||||
|
view_type: e.viewType || 0,
|
||||||
|
ext_info: e.extInfo,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
addCard: function (e) {
|
||||||
|
for (var n = e.cardList, i = [], t = 0, o = n.length; t < o; ++t) {
|
||||||
|
var r = n[t],
|
||||||
|
r = { card_id: r.cardId, card_ext: r.cardExt };
|
||||||
|
i.push(r);
|
||||||
|
}
|
||||||
|
k(
|
||||||
|
a.addCard,
|
||||||
|
{ card_list: i },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
if ((n = e.card_list)) {
|
||||||
|
for (var n, i = 0, t = (n = JSON.parse(n)).length; i < t; ++i) {
|
||||||
|
var o = n[i];
|
||||||
|
(o.cardId = o.card_id),
|
||||||
|
(o.cardExt = o.card_ext),
|
||||||
|
(o.isSuccess = !!o.is_succ),
|
||||||
|
delete o.card_id,
|
||||||
|
delete o.card_ext,
|
||||||
|
delete o.is_succ;
|
||||||
|
}
|
||||||
|
(e.cardList = n), delete e.card_list;
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
chooseCard: function (e) {
|
||||||
|
k(
|
||||||
|
"chooseCard",
|
||||||
|
{
|
||||||
|
app_id: h.appId,
|
||||||
|
location_id: e.shopId || "",
|
||||||
|
sign_type: e.signType || "SHA1",
|
||||||
|
card_id: e.cardId || "",
|
||||||
|
card_type: e.cardType || "",
|
||||||
|
card_sign: e.cardSign,
|
||||||
|
time_stamp: e.timestamp + "",
|
||||||
|
nonce_str: e.nonceStr,
|
||||||
|
},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
(e.cardList = e.choose_card_info), delete e.choose_card_info;
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openCard: function (e) {
|
||||||
|
for (var n = e.cardList, i = [], t = 0, o = n.length; t < o; ++t) {
|
||||||
|
var r = n[t],
|
||||||
|
r = { card_id: r.cardId, code: r.code };
|
||||||
|
i.push(r);
|
||||||
|
}
|
||||||
|
k(a.openCard, { card_list: i }, e);
|
||||||
|
},
|
||||||
|
consumeAndShareCard: function (e) {
|
||||||
|
k(
|
||||||
|
a.consumeAndShareCard,
|
||||||
|
{ consumedCardId: e.cardId, consumedCode: e.code },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
chooseWXPay: function (e) {
|
||||||
|
k(a.chooseWXPay, x(e), e), B({ jsApiName: "chooseWXPay" });
|
||||||
|
},
|
||||||
|
openEnterpriseRedPacket: function (e) {
|
||||||
|
k(a.openEnterpriseRedPacket, x(e), e);
|
||||||
|
},
|
||||||
|
startSearchBeacons: function (e) {
|
||||||
|
k(a.startSearchBeacons, { ticket: e.ticket }, e);
|
||||||
|
},
|
||||||
|
stopSearchBeacons: function (e) {
|
||||||
|
k(a.stopSearchBeacons, {}, e);
|
||||||
|
},
|
||||||
|
onSearchBeacons: function (e) {
|
||||||
|
M(a.onSearchBeacons, e);
|
||||||
|
},
|
||||||
|
openEnterpriseChat: function (e) {
|
||||||
|
k(
|
||||||
|
"openEnterpriseChat",
|
||||||
|
{ useridlist: e.userIds, chatname: e.groupName },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
launchMiniProgram: function (e) {
|
||||||
|
k(
|
||||||
|
"launchMiniProgram",
|
||||||
|
{
|
||||||
|
targetAppId: e.targetAppId,
|
||||||
|
path: (function (e) {
|
||||||
|
var n;
|
||||||
|
if ("string" == typeof e && 0 < e.length)
|
||||||
|
return (
|
||||||
|
(n = e.split("?")[0]),
|
||||||
|
(n += ".html"),
|
||||||
|
void 0 !== (e = e.split("?")[1]) ? n + "?" + e : n
|
||||||
|
);
|
||||||
|
})(e.path),
|
||||||
|
envVersion: e.envVersion,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openBusinessView: function (e) {
|
||||||
|
k(
|
||||||
|
"openBusinessView",
|
||||||
|
{
|
||||||
|
businessType: e.businessType,
|
||||||
|
queryString: e.queryString || "",
|
||||||
|
envVersion: e.envVersion,
|
||||||
|
},
|
||||||
|
((e._complete = function (n) {
|
||||||
|
if (l) {
|
||||||
|
var e = n.extraData;
|
||||||
|
if (e)
|
||||||
|
try {
|
||||||
|
n.extraData = JSON.parse(e);
|
||||||
|
} catch (e) {
|
||||||
|
n.extraData = {};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
miniProgram: {
|
||||||
|
navigateBack: function (e) {
|
||||||
|
(e = e || {}),
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "navigateBack", arg: { delta: e.delta || 1 } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
navigateTo: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "navigateTo", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
redirectTo: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "redirectTo", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
switchTab: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "switchTab", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
reLaunch: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "reLaunch", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
postMessage: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "postMessage", arg: e.data || {} },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
getEnv: function (e) {
|
||||||
|
O(function () {
|
||||||
|
e({ miniprogram: "miniprogram" === r.__wxjs_environment });
|
||||||
|
});
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
(w = 1),
|
||||||
|
(T = {}),
|
||||||
|
n.addEventListener(
|
||||||
|
"error",
|
||||||
|
function (e) {
|
||||||
|
var n, i, t;
|
||||||
|
l ||
|
||||||
|
((t = (n = e.target).tagName),
|
||||||
|
(i = n.src),
|
||||||
|
"IMG" != t && "VIDEO" != t && "AUDIO" != t && "SOURCE" != t) ||
|
||||||
|
(-1 != i.indexOf("wxlocalresource://") &&
|
||||||
|
(e.preventDefault(),
|
||||||
|
e.stopPropagation(),
|
||||||
|
(t = n["wx-id"]) || ((t = w++), (n["wx-id"] = t)),
|
||||||
|
T[t] ||
|
||||||
|
((T[t] = !0),
|
||||||
|
wx.ready(function () {
|
||||||
|
wx.getLocalImgData({
|
||||||
|
localId: i,
|
||||||
|
success: function (e) {
|
||||||
|
n.src = e.localData;
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}))));
|
||||||
|
},
|
||||||
|
!0
|
||||||
|
),
|
||||||
|
n.addEventListener(
|
||||||
|
"load",
|
||||||
|
function (e) {
|
||||||
|
var n;
|
||||||
|
l ||
|
||||||
|
((n = (e = e.target).tagName),
|
||||||
|
e.src,
|
||||||
|
"IMG" != n && "VIDEO" != n && "AUDIO" != n && "SOURCE" != n) ||
|
||||||
|
((n = e["wx-id"]) && (T[n] = !1));
|
||||||
|
},
|
||||||
|
!0
|
||||||
|
),
|
||||||
|
e && (r.wx = r.jWeixin = _),
|
||||||
|
_
|
||||||
|
);
|
||||||
|
else return r.jWeixin;
|
||||||
|
function k(n, e, i) {
|
||||||
|
r.WeixinJSBridge
|
||||||
|
? WeixinJSBridge.invoke(n, P(e), function (e) {
|
||||||
|
V(n, e, i);
|
||||||
|
})
|
||||||
|
: C(n, i);
|
||||||
|
}
|
||||||
|
function M(n, i, t) {
|
||||||
|
r.WeixinJSBridge
|
||||||
|
? WeixinJSBridge.on(n, function (e) {
|
||||||
|
t && t.trigger && t.trigger(e), V(n, e, i);
|
||||||
|
})
|
||||||
|
: C(n, t || i);
|
||||||
|
}
|
||||||
|
function P(e) {
|
||||||
|
return (
|
||||||
|
((e = e || {}).appId = h.appId),
|
||||||
|
(e.verifyAppId = h.appId),
|
||||||
|
(e.verifySignType = "sha1"),
|
||||||
|
(e.verifyTimestamp = h.timestamp + ""),
|
||||||
|
(e.verifyNonceStr = h.nonceStr),
|
||||||
|
(e.verifySignature = h.signature),
|
||||||
|
e
|
||||||
|
);
|
||||||
|
}
|
||||||
|
function x(e) {
|
||||||
|
return {
|
||||||
|
timeStamp: e.timestamp + "",
|
||||||
|
nonceStr: e.nonceStr,
|
||||||
|
package: e.package,
|
||||||
|
paySign: e.paySign,
|
||||||
|
signType: e.signType || "SHA1",
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function V(e, n, i) {
|
||||||
|
("openEnterpriseChat" != e && "openBusinessView" !== e) ||
|
||||||
|
(n.errCode = n.err_code),
|
||||||
|
delete n.err_code,
|
||||||
|
delete n.err_desc,
|
||||||
|
delete n.err_detail;
|
||||||
|
var t = n.errMsg,
|
||||||
|
e =
|
||||||
|
(t ||
|
||||||
|
((t = n.err_msg),
|
||||||
|
delete n.err_msg,
|
||||||
|
(t = (function (e, n) {
|
||||||
|
var i = c[e];
|
||||||
|
i && (e = i);
|
||||||
|
i = "ok";
|
||||||
|
{
|
||||||
|
var t;
|
||||||
|
n &&
|
||||||
|
((t = n.indexOf(":")),
|
||||||
|
("access denied" !=
|
||||||
|
(i = (i = (i =
|
||||||
|
-1 !=
|
||||||
|
(i =
|
||||||
|
-1 !=
|
||||||
|
(i =
|
||||||
|
"failed" ==
|
||||||
|
(i = "confirm" == (i = n.substring(t + 1)) ? "ok" : i)
|
||||||
|
? "fail"
|
||||||
|
: i).indexOf("failed_")
|
||||||
|
? i.substring(7)
|
||||||
|
: i).indexOf("fail_")
|
||||||
|
? i.substring(5)
|
||||||
|
: i).replace(/_/g, " ")).toLowerCase()) &&
|
||||||
|
"no permission to execute" != i) ||
|
||||||
|
(i = "permission denied"),
|
||||||
|
"" ==
|
||||||
|
(i =
|
||||||
|
"config" == e && "function not exist" == i ? "ok" : i)) &&
|
||||||
|
(i = "fail");
|
||||||
|
}
|
||||||
|
return (n = e + ":" + i);
|
||||||
|
})(e, t)),
|
||||||
|
(n.errMsg = t)),
|
||||||
|
(i = i || {})._complete && (i._complete(n), delete i._complete),
|
||||||
|
(t = n.errMsg || ""),
|
||||||
|
h.debug && !i.isInnerInvoke && alert(JSON.stringify(n)),
|
||||||
|
t.indexOf(":"));
|
||||||
|
switch (t.substring(e + 1)) {
|
||||||
|
case "ok":
|
||||||
|
i.success && i.success(n);
|
||||||
|
break;
|
||||||
|
case "cancel":
|
||||||
|
i.cancel && i.cancel(n);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
i.fail && i.fail(n);
|
||||||
|
}
|
||||||
|
i.complete && i.complete(n);
|
||||||
|
}
|
||||||
|
function A(e) {
|
||||||
|
if (e) {
|
||||||
|
for (var n = 0, i = e.length; n < i; ++n) {
|
||||||
|
var t = e[n],
|
||||||
|
t = a[t];
|
||||||
|
t && (e[n] = t);
|
||||||
|
}
|
||||||
|
return e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function C(e, n) {
|
||||||
|
var i;
|
||||||
|
!h.debug ||
|
||||||
|
(n && n.isInnerInvoke) ||
|
||||||
|
((i = c[e]) && (e = i),
|
||||||
|
n && n._complete && delete n._complete,
|
||||||
|
console.log('"' + e + '",', n || ""));
|
||||||
|
}
|
||||||
|
function B(n) {
|
||||||
|
var i;
|
||||||
|
o ||
|
||||||
|
s ||
|
||||||
|
h.debug ||
|
||||||
|
p < "6.0.2" ||
|
||||||
|
g.systemType < 0 ||
|
||||||
|
((i = new Image()),
|
||||||
|
(g.appId = h.appId),
|
||||||
|
(g.initTime = m.initEndTime - m.initStartTime),
|
||||||
|
(g.preVerifyTime = m.preVerifyEndTime - m.preVerifyStartTime),
|
||||||
|
_.getNetworkType({
|
||||||
|
isInnerInvoke: !0,
|
||||||
|
success: function (e) {
|
||||||
|
g.networkType = e.networkType;
|
||||||
|
e =
|
||||||
|
"https://open.weixin.qq.com/sdk/report?v=" +
|
||||||
|
g.version +
|
||||||
|
"&o=" +
|
||||||
|
g.isPreVerifyOk +
|
||||||
|
"&s=" +
|
||||||
|
g.systemType +
|
||||||
|
"&c=" +
|
||||||
|
g.clientVersion +
|
||||||
|
"&a=" +
|
||||||
|
g.appId +
|
||||||
|
"&n=" +
|
||||||
|
g.networkType +
|
||||||
|
"&i=" +
|
||||||
|
g.initTime +
|
||||||
|
"&p=" +
|
||||||
|
g.preVerifyTime +
|
||||||
|
"&u=" +
|
||||||
|
g.url +
|
||||||
|
"&jsapi_name=" +
|
||||||
|
(n ? n.jsApiName : "");
|
||||||
|
i.src = e;
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
function L() {
|
||||||
|
return new Date().getTime();
|
||||||
|
}
|
||||||
|
function O(e) {
|
||||||
|
d &&
|
||||||
|
(r.WeixinJSBridge
|
||||||
|
? e()
|
||||||
|
: n.addEventListener &&
|
||||||
|
n.addEventListener("WeixinJSBridgeReady", e, !1));
|
||||||
|
}
|
||||||
|
});
|
||||||
15
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/package.json
generated
vendored
Normal file
15
node_modules/.store/weixin-js-sdk@1.6.5/node_modules/weixin-js-sdk/package.json
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"name": "weixin-js-sdk",
|
||||||
|
"version": "1.6.5",
|
||||||
|
"license": "MIT",
|
||||||
|
"main": "index.js",
|
||||||
|
"description": "微信官方 js-sdk npm 安装版,支持 typescript",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/yanxi123-com/weixin-js-sdk"
|
||||||
|
},
|
||||||
|
"homepage": "https://yanxi123.com/",
|
||||||
|
"__npminstall_done": true,
|
||||||
|
"_from": "weixin-js-sdk@1.6.5",
|
||||||
|
"_resolved": "https://registry.npmmirror.com/weixin-js-sdk/-/weixin-js-sdk-1.6.5.tgz"
|
||||||
|
}
|
||||||
21
node_modules/weixin-js-sdk/LICENSE
generated
vendored
Normal file
21
node_modules/weixin-js-sdk/LICENSE
generated
vendored
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
MIT License
|
||||||
|
|
||||||
|
Copyright (c) 2023 Yanxi
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
36
node_modules/weixin-js-sdk/README.md
generated
vendored
Normal file
36
node_modules/weixin-js-sdk/README.md
generated
vendored
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
微信官方 js-sdk
|
||||||
|
----
|
||||||
|
|
||||||
|
说明: 仅将官方 js-sdk 发布到 npm,支持 CommonJS,便于 browserify, webpack 等直接使用,支持 TypeScript。
|
||||||
|
|
||||||
|
|
||||||
|
官方 JS 源码: https://res.wx.qq.com/open/js/jweixin-1.6.0.js
|
||||||
|
|
||||||
|
官方使用说明: https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/JS-SDK.html
|
||||||
|
|
||||||
|
安装:
|
||||||
|
```shell
|
||||||
|
npm install weixin-js-sdk
|
||||||
|
```
|
||||||
|
|
||||||
|
使用:
|
||||||
|
```javascript
|
||||||
|
// commonjs
|
||||||
|
var wx = require('weixin-js-sdk');
|
||||||
|
|
||||||
|
// es module
|
||||||
|
import wx from 'weixin-js-sdk'
|
||||||
|
```
|
||||||
|
|
||||||
|
### Old versions
|
||||||
|
|
||||||
|
* [1.0.0](https://github.com/yanxi123-com/weixin-js-sdk/tree/1.0.0)
|
||||||
|
* [1.2.0](https://github.com/yanxi123-com/weixin-js-sdk/tree/1.2.0)
|
||||||
|
|
||||||
|
### 个人主页
|
||||||
|
|
||||||
|
* [https://yanxi123.com/](https://yanxi123.com/)
|
||||||
|
|
||||||
|
### 感谢
|
||||||
|
|
||||||
|
TypeScript 定义文件来自 [wx-jssdk-ts](https://github.com/zhaoky/wx-jssdk-ts/blob/master/index.d.ts)
|
||||||
601
node_modules/weixin-js-sdk/index.d.ts
generated
vendored
Normal file
601
node_modules/weixin-js-sdk/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,601 @@
|
|||||||
|
// Type definitions for weixin jssdk 1.6.0
|
||||||
|
// Project: https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115
|
||||||
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
||||||
|
|
||||||
|
declare namespace wx {
|
||||||
|
type ImageSizeType = "original" | "compressed";
|
||||||
|
type ImageSourceType = "album" | "camera";
|
||||||
|
type VideoSourceType = "album" | "camera";
|
||||||
|
type ApiMethod =
|
||||||
|
| "onMenuShareTimeline"
|
||||||
|
| "onMenuShareAppMessage"
|
||||||
|
| "onMenuShareQQ"
|
||||||
|
| "onMenuShareWeibo"
|
||||||
|
| "onMenuShareQZone"
|
||||||
|
| "updateAppMessageShareData"
|
||||||
|
| "updateTimelineShareData"
|
||||||
|
| "startRecord"
|
||||||
|
| "stopRecord"
|
||||||
|
| "onVoiceRecordEnd"
|
||||||
|
| "playVoice"
|
||||||
|
| "pauseVoice"
|
||||||
|
| "stopVoice"
|
||||||
|
| "onVoicePlayEnd"
|
||||||
|
| "uploadVoice"
|
||||||
|
| "downloadVoice"
|
||||||
|
| "chooseImage"
|
||||||
|
| "previewImage"
|
||||||
|
| "uploadImage"
|
||||||
|
| "downloadImage"
|
||||||
|
| "translateVoice"
|
||||||
|
| "getNetworkType"
|
||||||
|
| "openLocation"
|
||||||
|
| "getLocation"
|
||||||
|
| "hideOptionMenu"
|
||||||
|
| "showOptionMenu"
|
||||||
|
| "hideMenuItems"
|
||||||
|
| "showMenuItems"
|
||||||
|
| "hideAllNonBaseMenuItem"
|
||||||
|
| "showAllNonBaseMenuItem"
|
||||||
|
| "closeWindow"
|
||||||
|
| "scanQRCode"
|
||||||
|
| "chooseWXPay"
|
||||||
|
| "openProductSpecificView"
|
||||||
|
| "addCard"
|
||||||
|
| "chooseCard"
|
||||||
|
| "openCard";
|
||||||
|
// 所有JS接口列表
|
||||||
|
type jsApiList = ApiMethod[];
|
||||||
|
|
||||||
|
// 开放标签列表
|
||||||
|
// https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_Open_Tag.html
|
||||||
|
type openTag = "wx-open-launch-weapp" | "wx-open-launch-app" | "wx-open-subscribe" | "wx-open-audio"
|
||||||
|
type openTagList = openTag[];
|
||||||
|
|
||||||
|
// 所有菜单项列表
|
||||||
|
// 基本类
|
||||||
|
type menuBase =
|
||||||
|
| "menuItem:exposeArticle" // 举报
|
||||||
|
| "menuItem:setFont" // 调整字体
|
||||||
|
| "menuItem:dayMode" // 日间模式
|
||||||
|
| "menuItem:nightMode" // 夜间模式
|
||||||
|
| "menuItem:refresh" // 刷新
|
||||||
|
| "menuItem:profile" // 查看公众号(已添加)
|
||||||
|
| "menuItem:addContact"; // 查看公众号(未添加)
|
||||||
|
// 传播类
|
||||||
|
type menuShare =
|
||||||
|
| "menuItem:share:appMessage" // 发送给朋友
|
||||||
|
| "menuItem:share:timeline" // 分享到朋友圈
|
||||||
|
| "menuItem:share:qq" // 分享到QQ
|
||||||
|
| "menuItem:share:weiboApp" // 分享到Weibo
|
||||||
|
| "menuItem:favorite" // 收藏
|
||||||
|
| "menuItem:share:facebook" // 分享到FB
|
||||||
|
| "menuItem:share:QZone"; // 分享到 QQ 空间
|
||||||
|
|
||||||
|
// 保护类
|
||||||
|
type menuProtected =
|
||||||
|
| "menuItem:editTag" // 编辑标签
|
||||||
|
| "menuItem:delete" // 删除
|
||||||
|
| "menuItem:copyUrl" // 复制链接
|
||||||
|
| "menuItem:originPage" // 原网页
|
||||||
|
| "menuItem:readMode" // 阅读模式
|
||||||
|
| "menuItem:openWithQQBrowser" // 在QQ浏览器中打开
|
||||||
|
| "menuItem:openWithSafari" // 在Safari中打开
|
||||||
|
| "menuItem:share:email" // 邮件
|
||||||
|
| "menuItem:share:brand"; // 一些特殊公众号
|
||||||
|
|
||||||
|
type menuList = Array<menuBase | menuProtected | menuShare>;
|
||||||
|
|
||||||
|
function config(conf: {
|
||||||
|
debug?: boolean; // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
|
||||||
|
appId: string; // 必填,公众号的唯一标识
|
||||||
|
timestamp: number; // 必填,生成签名的时间戳
|
||||||
|
nonceStr: string; // 必填,生成签名的随机串
|
||||||
|
signature: string; // 必填,签名,见附录1
|
||||||
|
jsApiList?: jsApiList; // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
|
||||||
|
openTagList?: openTagList;
|
||||||
|
}): void;
|
||||||
|
|
||||||
|
interface Resouce {
|
||||||
|
localId: string;
|
||||||
|
}
|
||||||
|
interface BaseParams {
|
||||||
|
success?(...args: any[]): void;
|
||||||
|
/** 接口调用失败的回调函数 */
|
||||||
|
fail?(...args: any[]): void;
|
||||||
|
/** 接口取消调用的回调函数 */
|
||||||
|
cancel?(...args: any[]): void;
|
||||||
|
/** 接口调用结束的回调函数(调用成功、失败都会执行) */
|
||||||
|
complete?(...args: any[]): void;
|
||||||
|
}
|
||||||
|
function ready(fn: () => void): void;
|
||||||
|
function error(fn: (err: { errMsg: string }) => void): void;
|
||||||
|
|
||||||
|
interface IcheckJsApi extends BaseParams {
|
||||||
|
jsApiList: jsApiList; // 需要检测的JS接口列表,所有JS接口列表见附录2,
|
||||||
|
// 以键值对的形式返回,可用的api值true,不可用为false
|
||||||
|
// 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"}
|
||||||
|
success(res: {
|
||||||
|
checkResult: { [api: string]: boolean };
|
||||||
|
errMsg: string;
|
||||||
|
}): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 判断当前客户端版本是否支持指定JS接口
|
||||||
|
* 备注:checkJsApi接口是客户端6.0.2新引入的一个预留接口,第一期开放的接口均可不使用checkJsApi来检测。
|
||||||
|
*/
|
||||||
|
function checkJsApi(params: IcheckJsApi): void;
|
||||||
|
|
||||||
|
interface IonMenuShareTimeline extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/*=============================基础接口================================*/
|
||||||
|
/**
|
||||||
|
* 获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareTimeline(params: IonMenuShareTimeline): void;
|
||||||
|
|
||||||
|
interface IonMenuShareAppMessage extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
type?: "music" | "video或link" | "link"; // 分享类型,music、video或link,不填默认为link
|
||||||
|
dataUrl?: string; // 如果type是music或video,则要提供数据链接,默认为空
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享给朋友”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareAppMessage(params: IonMenuShareAppMessage): void;
|
||||||
|
|
||||||
|
interface IonMenuShareQQ extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到QQ”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareQQ(params: IonMenuShareQQ): void;
|
||||||
|
|
||||||
|
interface IonMenuShareWeibo extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareWeibo(params: IonMenuShareWeibo): void;
|
||||||
|
|
||||||
|
interface IonMenuShareQZone extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
// 用户取消分享后执行的回调函数
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到QQ空间”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function onMenuShareQZone(params: IonMenuShareQZone): void;
|
||||||
|
|
||||||
|
interface IupdateAppMessageShareData extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
desc: string; // 分享描述
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享给朋友”及“分享到QQ”按钮点击状态及自定义分享内容接口(新)
|
||||||
|
*/
|
||||||
|
function updateAppMessageShareData(params: IupdateAppMessageShareData): void;
|
||||||
|
|
||||||
|
interface IupdateTimelineShareData extends BaseParams {
|
||||||
|
title: string; // 分享标题
|
||||||
|
link: string; // 分享链接
|
||||||
|
imgUrl: string; // 分享图标
|
||||||
|
// 用户确认分享后执行的回调函数
|
||||||
|
success(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取“分享到朋友圈”及“分享到QQ空间”按钮点击状态及自定义分享内容接口
|
||||||
|
*/
|
||||||
|
function updateTimelineShareData(params: IupdateTimelineShareData): void;
|
||||||
|
/*=============================基础接口================================*/
|
||||||
|
|
||||||
|
/*=============================图像接口================================*/
|
||||||
|
interface IchooseImage extends BaseParams {
|
||||||
|
/** 最多可以选择的图片张数,默认9 */
|
||||||
|
count?: number;
|
||||||
|
/** original 原图,compressed 压缩图,默认二者都有 */
|
||||||
|
sizeType?: ImageSizeType[];
|
||||||
|
/** album 从相册选图,camera 使用相机,默认二者都有 */
|
||||||
|
sourceType?: ImageSourceType[];
|
||||||
|
/** 成功则返回图片的本地文件路径列表 tempFilePaths */
|
||||||
|
success(res: {
|
||||||
|
sourceType: string; // weixin album camera
|
||||||
|
localIds: string[];
|
||||||
|
errMsg: string;
|
||||||
|
}): void;
|
||||||
|
cancel(): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 从本地相册选择图片或使用相机拍照。
|
||||||
|
*/
|
||||||
|
function chooseImage(params: IchooseImage): void;
|
||||||
|
|
||||||
|
interface IpreviewImage extends BaseParams {
|
||||||
|
current: string; // 当前显示图片的http链接
|
||||||
|
urls: string[]; // 需要预览的图片http链接列表
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 预览图片接口
|
||||||
|
*/
|
||||||
|
function previewImage(params: IpreviewImage): void;
|
||||||
|
|
||||||
|
interface IuploadResource extends BaseParams {
|
||||||
|
localId: string; // 需要上传的图片的本地ID,由chooseImage接口获得
|
||||||
|
isShowProgressTips: number; // 默认为1,显示进度提示
|
||||||
|
// 返回图片的服务器端ID
|
||||||
|
success(res: { serverId: string }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 上传图片接口
|
||||||
|
*/
|
||||||
|
function uploadImage(params: IuploadResource): void;
|
||||||
|
|
||||||
|
interface IdownloadResource extends BaseParams {
|
||||||
|
serverId: string; // 需要下载的图片的服务器端ID,由uploadImage接口获得
|
||||||
|
isShowProgressTips: number; // 默认为1,显示进度提示
|
||||||
|
// 返回图片下载后的本地ID
|
||||||
|
success(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 下载图片接口
|
||||||
|
*/
|
||||||
|
function downloadImage(params: IdownloadResource): void;
|
||||||
|
|
||||||
|
interface IgetLocalImgData extends BaseParams {
|
||||||
|
localId: string; // 图片的localID
|
||||||
|
// localData是图片的base64数据,可以用img标签显示
|
||||||
|
success(res: { localData: string }): void;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取本地图片接口
|
||||||
|
*/
|
||||||
|
function getLocalImgData(params: IgetLocalImgData): void;
|
||||||
|
/*=============================图像接口================================*/
|
||||||
|
/*=============================音频接口================================*/
|
||||||
|
/**
|
||||||
|
* 开始录音接口
|
||||||
|
*/
|
||||||
|
function startRecord(): void;
|
||||||
|
|
||||||
|
interface IstopRecord extends BaseParams {
|
||||||
|
success(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 停止录音接口
|
||||||
|
*/
|
||||||
|
function stopRecord(params: IstopRecord): void;
|
||||||
|
|
||||||
|
interface IonVoiceRecordEnd extends BaseParams {
|
||||||
|
// 录音时间超过一分钟没有停止的时候会执行 complete 回调
|
||||||
|
complete(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 监听录音自动停止接口
|
||||||
|
*/
|
||||||
|
function onVoiceRecordEnd(params: IonVoiceRecordEnd): void;
|
||||||
|
|
||||||
|
interface IplaypausestopVoice extends BaseParams {
|
||||||
|
localId: string; // 需要播放的音频的本地ID,由stopRecord接口获得
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 播放语音接口
|
||||||
|
*/
|
||||||
|
function playVoice(params: IplaypausestopVoice): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 暂停播放接口
|
||||||
|
*/
|
||||||
|
function pauseVoice(params: IplaypausestopVoice): void;
|
||||||
|
/**
|
||||||
|
* 停止播放接口
|
||||||
|
*/
|
||||||
|
function stopVoice(params: IplaypausestopVoice): void;
|
||||||
|
|
||||||
|
interface IonVoicePlayEnd extends BaseParams {
|
||||||
|
success(res: Resouce): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 监听语音播放完毕接口
|
||||||
|
*/
|
||||||
|
function onVoicePlayEnd(params: IonVoicePlayEnd): void;
|
||||||
|
/**
|
||||||
|
* 上传语音接口
|
||||||
|
* 备注:上传语音有效期3天,可用微信多媒体接口下载语音到自己的服务器
|
||||||
|
* ,此处获得的 serverId 即 media_id,参考文档
|
||||||
|
* ../12 / 58bfcfabbd501c7cd77c19bd9cfa8354.html
|
||||||
|
* 目前多媒体文件下载接口的频率限制为10000次/ 天,
|
||||||
|
* 如需要调高频率,请邮件weixin - open@qq.com,
|
||||||
|
* 邮件主题为【申请多媒体接口调用量】,请对你的项目进行简单描述,
|
||||||
|
* 附上产品体验链接,并对用户量和使用量进行说明。
|
||||||
|
*/
|
||||||
|
function uploadVoice(params: IuploadResource): void;
|
||||||
|
/**
|
||||||
|
* 下载语音接口
|
||||||
|
*/
|
||||||
|
function downloadVoice(params: IdownloadResource): void;
|
||||||
|
/*=============================音频接口================================*/
|
||||||
|
/*=============================智能接口================================*/
|
||||||
|
|
||||||
|
interface ItranslateVoice extends BaseParams {
|
||||||
|
localId: string; // 需要识别的音频的本地Id,由录音相关接口获得
|
||||||
|
isShowProgressTips: number; // 默认为1,显示进度提示
|
||||||
|
success(res: { translateResult: string }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 识别音频并返回识别结果接口
|
||||||
|
*/
|
||||||
|
function translateVoice(params: ItranslateVoice): void;
|
||||||
|
|
||||||
|
/*=============================智能接口================================*/
|
||||||
|
|
||||||
|
/*=============================设备信息================================*/
|
||||||
|
type networkType = "2g" | "3g" | "4g" | "wifi";
|
||||||
|
interface IgetNetworkType extends BaseParams {
|
||||||
|
success(res: { networkType: networkType }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取网络状态接口
|
||||||
|
*/
|
||||||
|
function getNetworkType(params: IgetNetworkType): void;
|
||||||
|
/*=============================设备信息================================*/
|
||||||
|
|
||||||
|
/*=============================地理位置================================*/
|
||||||
|
interface IopenLocation extends BaseParams {
|
||||||
|
latitude: number; // 纬度,浮点数,范围为90 ~ -90
|
||||||
|
longitude: number; // 经度,浮点数,范围为180 ~ -180。
|
||||||
|
name: string; // 位置名
|
||||||
|
address: string; // 地址详情说明
|
||||||
|
scale: number; // 地图缩放级别,整形值,范围从1~28。默认为最大
|
||||||
|
infoUrl: string; // 在查看位置界面底部显示的超链接,可点击跳转
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 使用微信内置地图查看位置接口
|
||||||
|
*/
|
||||||
|
function openLocation(params: IopenLocation): void;
|
||||||
|
|
||||||
|
interface IgetLocation extends BaseParams {
|
||||||
|
type: "wgs84" | "gcj02"; // 默认为wgs84的gps坐标,如果要返回直接给openLocation用的火星坐标,可传入'gcj02'
|
||||||
|
success(res: {
|
||||||
|
latitude: number; // 纬度,浮点数,范围为90 ~ -90
|
||||||
|
longitude: number; // 经度,浮点数,范围为180 ~ -180。
|
||||||
|
speed: number; // 速度,以米/每秒计
|
||||||
|
accuracy: number; // 位置精度
|
||||||
|
}): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 获取地理位置接口
|
||||||
|
*/
|
||||||
|
function getLocation(params: IgetLocation): void;
|
||||||
|
/*=============================地理位置================================*/
|
||||||
|
/*=============================摇一摇周边================================*/
|
||||||
|
interface IstartSearchBeacons extends BaseParams {
|
||||||
|
ticket: string; // 摇周边的业务ticket, 系统自动添加在摇出来的页面链接后面
|
||||||
|
// 开启查找完成后的回调函数
|
||||||
|
complete(argv: any): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 开启查找周边ibeacon设备接口
|
||||||
|
* 备注:如需接入摇一摇周边功能,请参考:申请开通摇一摇周边
|
||||||
|
*/
|
||||||
|
function startSearchBeacons(params: IstartSearchBeacons): void;
|
||||||
|
|
||||||
|
interface IstopSearchBeacons extends BaseParams {
|
||||||
|
// 关闭查找完成后的回调函数
|
||||||
|
complete(res: any): void;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 关闭查找周边ibeacon设备接口
|
||||||
|
*/
|
||||||
|
function stopSearchBeacons(params: IstopSearchBeacons): void;
|
||||||
|
|
||||||
|
interface IonSearchBeacons extends BaseParams {
|
||||||
|
// 回调函数,可以数组形式取得该商家注册的在周边的相关设备列表
|
||||||
|
complete(argv: any): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 监听周边ibeacon设备接口
|
||||||
|
*/
|
||||||
|
function onSearchBeacons(params: IonSearchBeacons): void;
|
||||||
|
/*=============================摇一摇周边================================*/
|
||||||
|
/*=============================界面操作================================*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 隐藏右上角菜单接口
|
||||||
|
*/
|
||||||
|
function hideOptionMenu(): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 显示右上角菜单接口
|
||||||
|
*/
|
||||||
|
function showOptionMenu(): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 关闭当前网页窗口接口
|
||||||
|
*/
|
||||||
|
function closeWindow(): void;
|
||||||
|
|
||||||
|
interface IhideMenuItems extends BaseParams {
|
||||||
|
menuList: Array<menuProtected | menuShare>; // 要隐藏的菜单项,只能隐藏“传播类”和“保护类”按钮,所有menu项见附录3
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 批量隐藏功能按钮接口
|
||||||
|
*/
|
||||||
|
function hideMenuItems(params: IhideMenuItems): void;
|
||||||
|
|
||||||
|
interface IshowMenuItems extends BaseParams {
|
||||||
|
menuList: menuList; // 要显示的菜单项,所有menu项见附录3
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 批量显示功能按钮接口
|
||||||
|
*/
|
||||||
|
function showMenuItems(params: IshowMenuItems): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 隐藏所有非基础按钮接口
|
||||||
|
* “基本类”按钮详见附录3
|
||||||
|
*/
|
||||||
|
function hideAllNonBaseMenuItem(): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 显示所有功能按钮接口
|
||||||
|
*/
|
||||||
|
function showAllNonBaseMenuItem(): void;
|
||||||
|
/*=============================界面操作================================*/
|
||||||
|
/*=============================微信扫一扫================================*/
|
||||||
|
|
||||||
|
type scanType = "qrCode" | "barCode";
|
||||||
|
|
||||||
|
interface IscanQRCode extends BaseParams {
|
||||||
|
needResult: 0 | 1; // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
|
||||||
|
scanType: scanType[]; // 可以指定扫二维码还是一维码,默认二者都有
|
||||||
|
// 当needResult 为 1 时,扫码返回的结果
|
||||||
|
success(res: { resultStr: string }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 调起微信扫一扫接口
|
||||||
|
*/
|
||||||
|
function scanQRCode(params: IscanQRCode): void;
|
||||||
|
/*=============================微信扫一扫================================*/
|
||||||
|
/*=============================微信小店================================*/
|
||||||
|
|
||||||
|
interface IopenProductSpecificView extends BaseParams {
|
||||||
|
productId: string; // 商品id
|
||||||
|
viewType: "0" | "1" | "2"; // 0.默认值,普通商品详情页1.扫一扫商品详情页2.小店商品详情页
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 跳转微信商品页接口
|
||||||
|
*/
|
||||||
|
function openProductSpecificView(params: IopenProductSpecificView): void;
|
||||||
|
/*=============================微信卡券================================*/
|
||||||
|
|
||||||
|
interface IchooseCard extends BaseParams {
|
||||||
|
shopId: string; // 门店Id
|
||||||
|
cardType: string; // 卡券类型
|
||||||
|
cardId: string; // 卡券Id
|
||||||
|
timestamp: number; // 卡券签名时间戳
|
||||||
|
nonceStr: string; // 卡券签名随机串
|
||||||
|
signType: string; // 签名方式,默认'SHA1'
|
||||||
|
cardSign: string; // 卡券签名
|
||||||
|
success(res: { cardList: string[] }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 拉取适用卡券列表并获取用户选择信息
|
||||||
|
*/
|
||||||
|
function chooseCard(params: IchooseCard): void;
|
||||||
|
|
||||||
|
interface IaddCard extends BaseParams {
|
||||||
|
cardList: Array<{
|
||||||
|
cardId: string;
|
||||||
|
cardExt: string;
|
||||||
|
}>; // 需要添加的卡券列表
|
||||||
|
success(res: { cardList: string[] }): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 批量添加卡券接口
|
||||||
|
*/
|
||||||
|
function addCard(): void;
|
||||||
|
|
||||||
|
interface IopenCard extends BaseParams {
|
||||||
|
cardList: Array<{
|
||||||
|
cardId: string;
|
||||||
|
code: string;
|
||||||
|
}>; // 需要打开的卡券列表
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 查看微信卡包中的卡券接口
|
||||||
|
*/
|
||||||
|
function openCard(params: IopenCard): void;
|
||||||
|
|
||||||
|
interface IconsumeAndShareCard extends BaseParams {
|
||||||
|
cardId: string;
|
||||||
|
code: string;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 核销后再次赠送卡券接口
|
||||||
|
*/
|
||||||
|
function consumeAndShareCard(params: IconsumeAndShareCard): void;
|
||||||
|
/*=============================微信卡券================================*/
|
||||||
|
/*=============================微信支付================================*/
|
||||||
|
|
||||||
|
interface IchooseWXPay extends BaseParams {
|
||||||
|
timestamp: number; // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
|
||||||
|
nonceStr: string; // 支付签名随机串,不长于 32 位
|
||||||
|
package: string; // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
|
||||||
|
signType: string; // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
|
||||||
|
paySign: string; // 支付签名
|
||||||
|
// 支付成功后的回调函数
|
||||||
|
success(res: any): void;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* 发起一个微信支付请求
|
||||||
|
*/
|
||||||
|
function chooseWXPay(params: IchooseWXPay): void;
|
||||||
|
/*=============================微信支付================================*/
|
||||||
|
/*=============================微信小程序==============================*/
|
||||||
|
interface miniProgramMethodsParams extends BaseParams {
|
||||||
|
url: string;
|
||||||
|
}
|
||||||
|
interface miniProgramMethods {
|
||||||
|
navigateTo(params: miniProgramMethodsParams): void;
|
||||||
|
navigateBack(params: miniProgramMethodsParams): void;
|
||||||
|
switchTab(params: miniProgramMethodsParams): void;
|
||||||
|
reLaunch(params: miniProgramMethodsParams): void;
|
||||||
|
redirectTo(params: miniProgramMethodsParams): void;
|
||||||
|
postMessage(params: { data: any }): void;
|
||||||
|
getEnv(fn: (res: any) => void): void;
|
||||||
|
}
|
||||||
|
const miniProgram: miniProgramMethods;
|
||||||
|
/*=============================微信小程序==============================*/
|
||||||
|
}
|
||||||
|
declare function wx(): void;
|
||||||
|
/*=============================微信内全局变量==============================*/
|
||||||
|
declare global {
|
||||||
|
interface Window {
|
||||||
|
WeixinJSBridge: any;
|
||||||
|
__wxjs_environment: any;
|
||||||
|
}
|
||||||
|
const WeixinJSBridge: any;
|
||||||
|
}
|
||||||
|
export default wx;
|
||||||
891
node_modules/weixin-js-sdk/index.js
generated
vendored
Normal file
891
node_modules/weixin-js-sdk/index.js
generated
vendored
Normal file
@@ -0,0 +1,891 @@
|
|||||||
|
!(function (e, n) {
|
||||||
|
module.exports = n(e);
|
||||||
|
})(typeof window === "object" && window, function (r, e) {
|
||||||
|
if (!r) {
|
||||||
|
console.warn("can't use weixin-js-sdk in server side");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var a, c, n, i, t, o, s, d, l, u, p, f, m, g, h, S, y, I, v, _, w, T;
|
||||||
|
if (!r.jWeixin)
|
||||||
|
return (
|
||||||
|
(a = {
|
||||||
|
config: "preVerifyJSAPI",
|
||||||
|
onMenuShareTimeline: "menu:share:timeline",
|
||||||
|
onMenuShareAppMessage: "menu:share:appmessage",
|
||||||
|
onMenuShareQQ: "menu:share:qq",
|
||||||
|
onMenuShareWeibo: "menu:share:weiboApp",
|
||||||
|
onMenuShareQZone: "menu:share:QZone",
|
||||||
|
previewImage: "imagePreview",
|
||||||
|
getLocation: "geoLocation",
|
||||||
|
openProductSpecificView: "openProductViewWithPid",
|
||||||
|
addCard: "batchAddCard",
|
||||||
|
openCard: "batchViewCard",
|
||||||
|
chooseWXPay: "getBrandWCPayRequest",
|
||||||
|
openEnterpriseRedPacket: "getRecevieBizHongBaoRequest",
|
||||||
|
startSearchBeacons: "startMonitoringBeacons",
|
||||||
|
stopSearchBeacons: "stopMonitoringBeacons",
|
||||||
|
onSearchBeacons: "onBeaconsInRange",
|
||||||
|
consumeAndShareCard: "consumedShareCard",
|
||||||
|
openAddress: "editAddress",
|
||||||
|
}),
|
||||||
|
(c = (function () {
|
||||||
|
var e,
|
||||||
|
n = {};
|
||||||
|
for (e in a) n[a[e]] = e;
|
||||||
|
return n;
|
||||||
|
})()),
|
||||||
|
(n = r.document),
|
||||||
|
(i = n.title),
|
||||||
|
(t = navigator.userAgent.toLowerCase()),
|
||||||
|
(f = navigator.platform.toLowerCase()),
|
||||||
|
(o = !(!f.match("mac") && !f.match("win"))),
|
||||||
|
(s = -1 != t.indexOf("wxdebugger")),
|
||||||
|
(d = -1 != t.indexOf("micromessenger")),
|
||||||
|
(l = -1 != t.indexOf("android")),
|
||||||
|
(u = -1 != t.indexOf("iphone") || -1 != t.indexOf("ipad")),
|
||||||
|
(p = (f =
|
||||||
|
t.match(/micromessenger\/(\d+\.\d+\.\d+)/) ||
|
||||||
|
t.match(/micromessenger\/(\d+\.\d+)/))
|
||||||
|
? f[1]
|
||||||
|
: ""),
|
||||||
|
(m = {
|
||||||
|
initStartTime: L(),
|
||||||
|
initEndTime: 0,
|
||||||
|
preVerifyStartTime: 0,
|
||||||
|
preVerifyEndTime: 0,
|
||||||
|
}),
|
||||||
|
(g = {
|
||||||
|
version: 1,
|
||||||
|
appId: "",
|
||||||
|
initTime: 0,
|
||||||
|
preVerifyTime: 0,
|
||||||
|
networkType: "",
|
||||||
|
isPreVerifyOk: 1,
|
||||||
|
systemType: u ? 1 : l ? 2 : -1,
|
||||||
|
clientVersion: p,
|
||||||
|
url: encodeURIComponent(location.href),
|
||||||
|
}),
|
||||||
|
(h = {}),
|
||||||
|
(S = { _completes: [] }),
|
||||||
|
(y = { state: 0, data: {} }),
|
||||||
|
O(function () {
|
||||||
|
m.initEndTime = L();
|
||||||
|
}),
|
||||||
|
(I = !1),
|
||||||
|
(v = []),
|
||||||
|
(_ = {
|
||||||
|
config: function (e) {
|
||||||
|
C("config", (h = e));
|
||||||
|
var o = !1 !== h.check;
|
||||||
|
O(function () {
|
||||||
|
if (o)
|
||||||
|
k(
|
||||||
|
a.config,
|
||||||
|
{
|
||||||
|
verifyJsApiList: A(h.jsApiList),
|
||||||
|
verifyOpenTagList: A(h.openTagList),
|
||||||
|
},
|
||||||
|
((S._complete = function (e) {
|
||||||
|
(m.preVerifyEndTime = L()), (y.state = 1), (y.data = e);
|
||||||
|
}),
|
||||||
|
(S.success = function (e) {
|
||||||
|
g.isPreVerifyOk = 0;
|
||||||
|
}),
|
||||||
|
(S.fail = function (e) {
|
||||||
|
S._fail ? S._fail(e) : (y.state = -1);
|
||||||
|
}),
|
||||||
|
(t = S._completes).push(function () {
|
||||||
|
B();
|
||||||
|
}),
|
||||||
|
(S.complete = function (e) {
|
||||||
|
for (var n = 0, i = t.length; n < i; ++n) t[n]();
|
||||||
|
S._completes = [];
|
||||||
|
}),
|
||||||
|
S)
|
||||||
|
),
|
||||||
|
(m.preVerifyStartTime = L());
|
||||||
|
else {
|
||||||
|
y.state = 1;
|
||||||
|
for (var e = S._completes, n = 0, i = e.length; n < i; ++n)
|
||||||
|
e[n]();
|
||||||
|
S._completes = [];
|
||||||
|
}
|
||||||
|
var t;
|
||||||
|
}),
|
||||||
|
_.invoke ||
|
||||||
|
((_.invoke = function (e, n, i) {
|
||||||
|
r.WeixinJSBridge && WeixinJSBridge.invoke(e, P(n), i);
|
||||||
|
}),
|
||||||
|
(_.on = function (e, n) {
|
||||||
|
r.WeixinJSBridge && WeixinJSBridge.on(e, n);
|
||||||
|
}));
|
||||||
|
},
|
||||||
|
ready: function (e) {
|
||||||
|
(0 != y.state || (S._completes.push(e), !d && h.debug)) && e();
|
||||||
|
},
|
||||||
|
error: function (e) {
|
||||||
|
p < "6.0.2" || (-1 == y.state ? e(y.data) : (S._fail = e));
|
||||||
|
},
|
||||||
|
checkJsApi: function (e) {
|
||||||
|
k(
|
||||||
|
"checkJsApi",
|
||||||
|
{ jsApiList: A(e.jsApiList) },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
l && (i = e.checkResult) && (e.checkResult = JSON.parse(i));
|
||||||
|
var n,
|
||||||
|
i = e,
|
||||||
|
t = i.checkResult;
|
||||||
|
for (n in t) {
|
||||||
|
var o = c[n];
|
||||||
|
o && ((t[o] = t[n]), delete t[n]);
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareTimeline: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareTimeline,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareTimeline",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.title || i,
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
type: e.type || "link",
|
||||||
|
data_url: e.dataUrl || "",
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareAppMessage: function (n) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareAppMessage,
|
||||||
|
{
|
||||||
|
complete: function (e) {
|
||||||
|
"favorite" === e.scene
|
||||||
|
? k("sendAppMessage", {
|
||||||
|
title: n.title || i,
|
||||||
|
desc: n.desc || "",
|
||||||
|
link: n.link || location.href,
|
||||||
|
img_url: n.imgUrl || "",
|
||||||
|
type: n.type || "link",
|
||||||
|
data_url: n.dataUrl || "",
|
||||||
|
})
|
||||||
|
: k(
|
||||||
|
"sendAppMessage",
|
||||||
|
{
|
||||||
|
title: n.title || i,
|
||||||
|
desc: n.desc || "",
|
||||||
|
link: n.link || location.href,
|
||||||
|
img_url: n.imgUrl || "",
|
||||||
|
type: n.type || "link",
|
||||||
|
data_url: n.dataUrl || "",
|
||||||
|
},
|
||||||
|
n
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
n
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareQQ: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareQQ,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareQQ",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.desc || "",
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareWeibo: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareWeibo,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareWeiboApp",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.desc || "",
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
onMenuShareQZone: function (e) {
|
||||||
|
M(
|
||||||
|
a.onMenuShareQZone,
|
||||||
|
{
|
||||||
|
complete: function () {
|
||||||
|
k(
|
||||||
|
"shareQZone",
|
||||||
|
{
|
||||||
|
title: e.title || i,
|
||||||
|
desc: e.desc || "",
|
||||||
|
img_url: e.imgUrl || "",
|
||||||
|
link: e.link || location.href,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
updateTimelineShareData: function (e) {
|
||||||
|
k(
|
||||||
|
"updateTimelineShareData",
|
||||||
|
{ title: e.title, link: e.link, imgUrl: e.imgUrl },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
updateAppMessageShareData: function (e) {
|
||||||
|
k(
|
||||||
|
"updateAppMessageShareData",
|
||||||
|
{ title: e.title, desc: e.desc, link: e.link, imgUrl: e.imgUrl },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
startRecord: function (e) {
|
||||||
|
k("startRecord", {}, e);
|
||||||
|
},
|
||||||
|
stopRecord: function (e) {
|
||||||
|
k("stopRecord", {}, e);
|
||||||
|
},
|
||||||
|
onVoiceRecordEnd: function (e) {
|
||||||
|
M("onVoiceRecordEnd", e);
|
||||||
|
},
|
||||||
|
playVoice: function (e) {
|
||||||
|
k("playVoice", { localId: e.localId }, e);
|
||||||
|
},
|
||||||
|
pauseVoice: function (e) {
|
||||||
|
k("pauseVoice", { localId: e.localId }, e);
|
||||||
|
},
|
||||||
|
stopVoice: function (e) {
|
||||||
|
k("stopVoice", { localId: e.localId }, e);
|
||||||
|
},
|
||||||
|
onVoicePlayEnd: function (e) {
|
||||||
|
M("onVoicePlayEnd", e);
|
||||||
|
},
|
||||||
|
uploadVoice: function (e) {
|
||||||
|
k(
|
||||||
|
"uploadVoice",
|
||||||
|
{
|
||||||
|
localId: e.localId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
downloadVoice: function (e) {
|
||||||
|
k(
|
||||||
|
"downloadVoice",
|
||||||
|
{
|
||||||
|
serverId: e.serverId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
translateVoice: function (e) {
|
||||||
|
k(
|
||||||
|
"translateVoice",
|
||||||
|
{
|
||||||
|
localId: e.localId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
chooseImage: function (e) {
|
||||||
|
k(
|
||||||
|
"chooseImage",
|
||||||
|
{
|
||||||
|
scene: "1|2",
|
||||||
|
count: e.count || 9,
|
||||||
|
sizeType: e.sizeType || ["original", "compressed"],
|
||||||
|
sourceType: e.sourceType || ["album", "camera"],
|
||||||
|
},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
if (l) {
|
||||||
|
var n = e.localIds;
|
||||||
|
try {
|
||||||
|
n && (e.localIds = JSON.parse(n));
|
||||||
|
} catch (e) {}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
getLocation: function (e) {
|
||||||
|
(e = e || {}),
|
||||||
|
k(
|
||||||
|
a.getLocation,
|
||||||
|
{ type: e.type || "wgs84" },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
delete e.type;
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
previewImage: function (e) {
|
||||||
|
k(a.previewImage, { current: e.current, urls: e.urls }, e);
|
||||||
|
},
|
||||||
|
uploadImage: function (e) {
|
||||||
|
k(
|
||||||
|
"uploadImage",
|
||||||
|
{
|
||||||
|
localId: e.localId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
downloadImage: function (e) {
|
||||||
|
k(
|
||||||
|
"downloadImage",
|
||||||
|
{
|
||||||
|
serverId: e.serverId,
|
||||||
|
isShowProgressTips: 0 == e.isShowProgressTips ? 0 : 1,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
getLocalImgData: function (e) {
|
||||||
|
!1 === I
|
||||||
|
? ((I = !0),
|
||||||
|
k(
|
||||||
|
"getLocalImgData",
|
||||||
|
{ localId: e.localId },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
var n;
|
||||||
|
(I = !1),
|
||||||
|
0 < v.length && ((n = v.shift()), wx.getLocalImgData(n));
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
))
|
||||||
|
: v.push(e);
|
||||||
|
},
|
||||||
|
getNetworkType: function (e) {
|
||||||
|
k(
|
||||||
|
"getNetworkType",
|
||||||
|
{},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
var n = e,
|
||||||
|
e = n.errMsg,
|
||||||
|
i = ((n.errMsg = "getNetworkType:ok"), n.subtype);
|
||||||
|
if ((delete n.subtype, i)) n.networkType = i;
|
||||||
|
else {
|
||||||
|
var i = e.indexOf(":"),
|
||||||
|
t = e.substring(i + 1);
|
||||||
|
switch (t) {
|
||||||
|
case "wifi":
|
||||||
|
case "edge":
|
||||||
|
case "wwan":
|
||||||
|
n.networkType = t;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
n.errMsg = "getNetworkType:fail";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openLocation: function (e) {
|
||||||
|
k(
|
||||||
|
"openLocation",
|
||||||
|
{
|
||||||
|
latitude: e.latitude,
|
||||||
|
longitude: e.longitude,
|
||||||
|
name: e.name || "",
|
||||||
|
address: e.address || "",
|
||||||
|
scale: e.scale || 28,
|
||||||
|
infoUrl: e.infoUrl || "",
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
hideOptionMenu: function (e) {
|
||||||
|
k("hideOptionMenu", {}, e);
|
||||||
|
},
|
||||||
|
showOptionMenu: function (e) {
|
||||||
|
k("showOptionMenu", {}, e);
|
||||||
|
},
|
||||||
|
closeWindow: function (e) {
|
||||||
|
k("closeWindow", {}, (e = e || {}));
|
||||||
|
},
|
||||||
|
hideMenuItems: function (e) {
|
||||||
|
k("hideMenuItems", { menuList: e.menuList }, e);
|
||||||
|
},
|
||||||
|
showMenuItems: function (e) {
|
||||||
|
k("showMenuItems", { menuList: e.menuList }, e);
|
||||||
|
},
|
||||||
|
hideAllNonBaseMenuItem: function (e) {
|
||||||
|
k("hideAllNonBaseMenuItem", {}, e);
|
||||||
|
},
|
||||||
|
showAllNonBaseMenuItem: function (e) {
|
||||||
|
k("showAllNonBaseMenuItem", {}, e);
|
||||||
|
},
|
||||||
|
scanQRCode: function (e) {
|
||||||
|
k(
|
||||||
|
"scanQRCode",
|
||||||
|
{
|
||||||
|
needResult: (e = e || {}).needResult || 0,
|
||||||
|
scanType: e.scanType || ["qrCode", "barCode"],
|
||||||
|
},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
var n;
|
||||||
|
u &&
|
||||||
|
(n = e.resultStr) &&
|
||||||
|
((n = JSON.parse(n)),
|
||||||
|
(e.resultStr = n && n.scan_code && n.scan_code.scan_result));
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openAddress: function (e) {
|
||||||
|
k(
|
||||||
|
a.openAddress,
|
||||||
|
{},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
((e = e).postalCode = e.addressPostalCode),
|
||||||
|
delete e.addressPostalCode,
|
||||||
|
(e.provinceName = e.proviceFirstStageName),
|
||||||
|
delete e.proviceFirstStageName,
|
||||||
|
(e.cityName = e.addressCitySecondStageName),
|
||||||
|
delete e.addressCitySecondStageName,
|
||||||
|
(e.countryName = e.addressCountiesThirdStageName),
|
||||||
|
delete e.addressCountiesThirdStageName,
|
||||||
|
(e.detailInfo = e.addressDetailInfo),
|
||||||
|
delete e.addressDetailInfo;
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openProductSpecificView: function (e) {
|
||||||
|
k(
|
||||||
|
a.openProductSpecificView,
|
||||||
|
{
|
||||||
|
pid: e.productId,
|
||||||
|
view_type: e.viewType || 0,
|
||||||
|
ext_info: e.extInfo,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
addCard: function (e) {
|
||||||
|
for (var n = e.cardList, i = [], t = 0, o = n.length; t < o; ++t) {
|
||||||
|
var r = n[t],
|
||||||
|
r = { card_id: r.cardId, card_ext: r.cardExt };
|
||||||
|
i.push(r);
|
||||||
|
}
|
||||||
|
k(
|
||||||
|
a.addCard,
|
||||||
|
{ card_list: i },
|
||||||
|
((e._complete = function (e) {
|
||||||
|
if ((n = e.card_list)) {
|
||||||
|
for (var n, i = 0, t = (n = JSON.parse(n)).length; i < t; ++i) {
|
||||||
|
var o = n[i];
|
||||||
|
(o.cardId = o.card_id),
|
||||||
|
(o.cardExt = o.card_ext),
|
||||||
|
(o.isSuccess = !!o.is_succ),
|
||||||
|
delete o.card_id,
|
||||||
|
delete o.card_ext,
|
||||||
|
delete o.is_succ;
|
||||||
|
}
|
||||||
|
(e.cardList = n), delete e.card_list;
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
chooseCard: function (e) {
|
||||||
|
k(
|
||||||
|
"chooseCard",
|
||||||
|
{
|
||||||
|
app_id: h.appId,
|
||||||
|
location_id: e.shopId || "",
|
||||||
|
sign_type: e.signType || "SHA1",
|
||||||
|
card_id: e.cardId || "",
|
||||||
|
card_type: e.cardType || "",
|
||||||
|
card_sign: e.cardSign,
|
||||||
|
time_stamp: e.timestamp + "",
|
||||||
|
nonce_str: e.nonceStr,
|
||||||
|
},
|
||||||
|
((e._complete = function (e) {
|
||||||
|
(e.cardList = e.choose_card_info), delete e.choose_card_info;
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openCard: function (e) {
|
||||||
|
for (var n = e.cardList, i = [], t = 0, o = n.length; t < o; ++t) {
|
||||||
|
var r = n[t],
|
||||||
|
r = { card_id: r.cardId, code: r.code };
|
||||||
|
i.push(r);
|
||||||
|
}
|
||||||
|
k(a.openCard, { card_list: i }, e);
|
||||||
|
},
|
||||||
|
consumeAndShareCard: function (e) {
|
||||||
|
k(
|
||||||
|
a.consumeAndShareCard,
|
||||||
|
{ consumedCardId: e.cardId, consumedCode: e.code },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
chooseWXPay: function (e) {
|
||||||
|
k(a.chooseWXPay, x(e), e), B({ jsApiName: "chooseWXPay" });
|
||||||
|
},
|
||||||
|
openEnterpriseRedPacket: function (e) {
|
||||||
|
k(a.openEnterpriseRedPacket, x(e), e);
|
||||||
|
},
|
||||||
|
startSearchBeacons: function (e) {
|
||||||
|
k(a.startSearchBeacons, { ticket: e.ticket }, e);
|
||||||
|
},
|
||||||
|
stopSearchBeacons: function (e) {
|
||||||
|
k(a.stopSearchBeacons, {}, e);
|
||||||
|
},
|
||||||
|
onSearchBeacons: function (e) {
|
||||||
|
M(a.onSearchBeacons, e);
|
||||||
|
},
|
||||||
|
openEnterpriseChat: function (e) {
|
||||||
|
k(
|
||||||
|
"openEnterpriseChat",
|
||||||
|
{ useridlist: e.userIds, chatname: e.groupName },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
launchMiniProgram: function (e) {
|
||||||
|
k(
|
||||||
|
"launchMiniProgram",
|
||||||
|
{
|
||||||
|
targetAppId: e.targetAppId,
|
||||||
|
path: (function (e) {
|
||||||
|
var n;
|
||||||
|
if ("string" == typeof e && 0 < e.length)
|
||||||
|
return (
|
||||||
|
(n = e.split("?")[0]),
|
||||||
|
(n += ".html"),
|
||||||
|
void 0 !== (e = e.split("?")[1]) ? n + "?" + e : n
|
||||||
|
);
|
||||||
|
})(e.path),
|
||||||
|
envVersion: e.envVersion,
|
||||||
|
},
|
||||||
|
e
|
||||||
|
);
|
||||||
|
},
|
||||||
|
openBusinessView: function (e) {
|
||||||
|
k(
|
||||||
|
"openBusinessView",
|
||||||
|
{
|
||||||
|
businessType: e.businessType,
|
||||||
|
queryString: e.queryString || "",
|
||||||
|
envVersion: e.envVersion,
|
||||||
|
},
|
||||||
|
((e._complete = function (n) {
|
||||||
|
if (l) {
|
||||||
|
var e = n.extraData;
|
||||||
|
if (e)
|
||||||
|
try {
|
||||||
|
n.extraData = JSON.parse(e);
|
||||||
|
} catch (e) {
|
||||||
|
n.extraData = {};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
e)
|
||||||
|
);
|
||||||
|
},
|
||||||
|
miniProgram: {
|
||||||
|
navigateBack: function (e) {
|
||||||
|
(e = e || {}),
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "navigateBack", arg: { delta: e.delta || 1 } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
navigateTo: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "navigateTo", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
redirectTo: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "redirectTo", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
switchTab: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "switchTab", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
reLaunch: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "reLaunch", arg: { url: e.url } },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
postMessage: function (e) {
|
||||||
|
O(function () {
|
||||||
|
k(
|
||||||
|
"invokeMiniProgramAPI",
|
||||||
|
{ name: "postMessage", arg: e.data || {} },
|
||||||
|
e
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
getEnv: function (e) {
|
||||||
|
O(function () {
|
||||||
|
e({ miniprogram: "miniprogram" === r.__wxjs_environment });
|
||||||
|
});
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
(w = 1),
|
||||||
|
(T = {}),
|
||||||
|
n.addEventListener(
|
||||||
|
"error",
|
||||||
|
function (e) {
|
||||||
|
var n, i, t;
|
||||||
|
l ||
|
||||||
|
((t = (n = e.target).tagName),
|
||||||
|
(i = n.src),
|
||||||
|
"IMG" != t && "VIDEO" != t && "AUDIO" != t && "SOURCE" != t) ||
|
||||||
|
(-1 != i.indexOf("wxlocalresource://") &&
|
||||||
|
(e.preventDefault(),
|
||||||
|
e.stopPropagation(),
|
||||||
|
(t = n["wx-id"]) || ((t = w++), (n["wx-id"] = t)),
|
||||||
|
T[t] ||
|
||||||
|
((T[t] = !0),
|
||||||
|
wx.ready(function () {
|
||||||
|
wx.getLocalImgData({
|
||||||
|
localId: i,
|
||||||
|
success: function (e) {
|
||||||
|
n.src = e.localData;
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}))));
|
||||||
|
},
|
||||||
|
!0
|
||||||
|
),
|
||||||
|
n.addEventListener(
|
||||||
|
"load",
|
||||||
|
function (e) {
|
||||||
|
var n;
|
||||||
|
l ||
|
||||||
|
((n = (e = e.target).tagName),
|
||||||
|
e.src,
|
||||||
|
"IMG" != n && "VIDEO" != n && "AUDIO" != n && "SOURCE" != n) ||
|
||||||
|
((n = e["wx-id"]) && (T[n] = !1));
|
||||||
|
},
|
||||||
|
!0
|
||||||
|
),
|
||||||
|
e && (r.wx = r.jWeixin = _),
|
||||||
|
_
|
||||||
|
);
|
||||||
|
else return r.jWeixin;
|
||||||
|
function k(n, e, i) {
|
||||||
|
r.WeixinJSBridge
|
||||||
|
? WeixinJSBridge.invoke(n, P(e), function (e) {
|
||||||
|
V(n, e, i);
|
||||||
|
})
|
||||||
|
: C(n, i);
|
||||||
|
}
|
||||||
|
function M(n, i, t) {
|
||||||
|
r.WeixinJSBridge
|
||||||
|
? WeixinJSBridge.on(n, function (e) {
|
||||||
|
t && t.trigger && t.trigger(e), V(n, e, i);
|
||||||
|
})
|
||||||
|
: C(n, t || i);
|
||||||
|
}
|
||||||
|
function P(e) {
|
||||||
|
return (
|
||||||
|
((e = e || {}).appId = h.appId),
|
||||||
|
(e.verifyAppId = h.appId),
|
||||||
|
(e.verifySignType = "sha1"),
|
||||||
|
(e.verifyTimestamp = h.timestamp + ""),
|
||||||
|
(e.verifyNonceStr = h.nonceStr),
|
||||||
|
(e.verifySignature = h.signature),
|
||||||
|
e
|
||||||
|
);
|
||||||
|
}
|
||||||
|
function x(e) {
|
||||||
|
return {
|
||||||
|
timeStamp: e.timestamp + "",
|
||||||
|
nonceStr: e.nonceStr,
|
||||||
|
package: e.package,
|
||||||
|
paySign: e.paySign,
|
||||||
|
signType: e.signType || "SHA1",
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function V(e, n, i) {
|
||||||
|
("openEnterpriseChat" != e && "openBusinessView" !== e) ||
|
||||||
|
(n.errCode = n.err_code),
|
||||||
|
delete n.err_code,
|
||||||
|
delete n.err_desc,
|
||||||
|
delete n.err_detail;
|
||||||
|
var t = n.errMsg,
|
||||||
|
e =
|
||||||
|
(t ||
|
||||||
|
((t = n.err_msg),
|
||||||
|
delete n.err_msg,
|
||||||
|
(t = (function (e, n) {
|
||||||
|
var i = c[e];
|
||||||
|
i && (e = i);
|
||||||
|
i = "ok";
|
||||||
|
{
|
||||||
|
var t;
|
||||||
|
n &&
|
||||||
|
((t = n.indexOf(":")),
|
||||||
|
("access denied" !=
|
||||||
|
(i = (i = (i =
|
||||||
|
-1 !=
|
||||||
|
(i =
|
||||||
|
-1 !=
|
||||||
|
(i =
|
||||||
|
"failed" ==
|
||||||
|
(i = "confirm" == (i = n.substring(t + 1)) ? "ok" : i)
|
||||||
|
? "fail"
|
||||||
|
: i).indexOf("failed_")
|
||||||
|
? i.substring(7)
|
||||||
|
: i).indexOf("fail_")
|
||||||
|
? i.substring(5)
|
||||||
|
: i).replace(/_/g, " ")).toLowerCase()) &&
|
||||||
|
"no permission to execute" != i) ||
|
||||||
|
(i = "permission denied"),
|
||||||
|
"" ==
|
||||||
|
(i =
|
||||||
|
"config" == e && "function not exist" == i ? "ok" : i)) &&
|
||||||
|
(i = "fail");
|
||||||
|
}
|
||||||
|
return (n = e + ":" + i);
|
||||||
|
})(e, t)),
|
||||||
|
(n.errMsg = t)),
|
||||||
|
(i = i || {})._complete && (i._complete(n), delete i._complete),
|
||||||
|
(t = n.errMsg || ""),
|
||||||
|
h.debug && !i.isInnerInvoke && alert(JSON.stringify(n)),
|
||||||
|
t.indexOf(":"));
|
||||||
|
switch (t.substring(e + 1)) {
|
||||||
|
case "ok":
|
||||||
|
i.success && i.success(n);
|
||||||
|
break;
|
||||||
|
case "cancel":
|
||||||
|
i.cancel && i.cancel(n);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
i.fail && i.fail(n);
|
||||||
|
}
|
||||||
|
i.complete && i.complete(n);
|
||||||
|
}
|
||||||
|
function A(e) {
|
||||||
|
if (e) {
|
||||||
|
for (var n = 0, i = e.length; n < i; ++n) {
|
||||||
|
var t = e[n],
|
||||||
|
t = a[t];
|
||||||
|
t && (e[n] = t);
|
||||||
|
}
|
||||||
|
return e;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function C(e, n) {
|
||||||
|
var i;
|
||||||
|
!h.debug ||
|
||||||
|
(n && n.isInnerInvoke) ||
|
||||||
|
((i = c[e]) && (e = i),
|
||||||
|
n && n._complete && delete n._complete,
|
||||||
|
console.log('"' + e + '",', n || ""));
|
||||||
|
}
|
||||||
|
function B(n) {
|
||||||
|
var i;
|
||||||
|
o ||
|
||||||
|
s ||
|
||||||
|
h.debug ||
|
||||||
|
p < "6.0.2" ||
|
||||||
|
g.systemType < 0 ||
|
||||||
|
((i = new Image()),
|
||||||
|
(g.appId = h.appId),
|
||||||
|
(g.initTime = m.initEndTime - m.initStartTime),
|
||||||
|
(g.preVerifyTime = m.preVerifyEndTime - m.preVerifyStartTime),
|
||||||
|
_.getNetworkType({
|
||||||
|
isInnerInvoke: !0,
|
||||||
|
success: function (e) {
|
||||||
|
g.networkType = e.networkType;
|
||||||
|
e =
|
||||||
|
"https://open.weixin.qq.com/sdk/report?v=" +
|
||||||
|
g.version +
|
||||||
|
"&o=" +
|
||||||
|
g.isPreVerifyOk +
|
||||||
|
"&s=" +
|
||||||
|
g.systemType +
|
||||||
|
"&c=" +
|
||||||
|
g.clientVersion +
|
||||||
|
"&a=" +
|
||||||
|
g.appId +
|
||||||
|
"&n=" +
|
||||||
|
g.networkType +
|
||||||
|
"&i=" +
|
||||||
|
g.initTime +
|
||||||
|
"&p=" +
|
||||||
|
g.preVerifyTime +
|
||||||
|
"&u=" +
|
||||||
|
g.url +
|
||||||
|
"&jsapi_name=" +
|
||||||
|
(n ? n.jsApiName : "");
|
||||||
|
i.src = e;
|
||||||
|
},
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
function L() {
|
||||||
|
return new Date().getTime();
|
||||||
|
}
|
||||||
|
function O(e) {
|
||||||
|
d &&
|
||||||
|
(r.WeixinJSBridge
|
||||||
|
? e()
|
||||||
|
: n.addEventListener &&
|
||||||
|
n.addEventListener("WeixinJSBridgeReady", e, !1));
|
||||||
|
}
|
||||||
|
});
|
||||||
15
node_modules/weixin-js-sdk/package.json
generated
vendored
Normal file
15
node_modules/weixin-js-sdk/package.json
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"name": "weixin-js-sdk",
|
||||||
|
"version": "1.6.5",
|
||||||
|
"license": "MIT",
|
||||||
|
"main": "index.js",
|
||||||
|
"description": "微信官方 js-sdk npm 安装版,支持 typescript",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/yanxi123-com/weixin-js-sdk"
|
||||||
|
},
|
||||||
|
"homepage": "https://yanxi123.com/",
|
||||||
|
"__npminstall_done": true,
|
||||||
|
"_from": "weixin-js-sdk@1.6.5",
|
||||||
|
"_resolved": "https://registry.npmmirror.com/weixin-js-sdk/-/weixin-js-sdk-1.6.5.tgz"
|
||||||
|
}
|
||||||
5
package.json
Normal file
5
package.json
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"dependencies": {
|
||||||
|
"weixin-js-sdk": "^1.6.5"
|
||||||
|
}
|
||||||
|
}
|
||||||
2626
pages/buy/buy.vue
2626
pages/buy/buy.vue
File diff suppressed because it is too large
Load Diff
336
pages/index/goods-category.css
Normal file
336
pages/index/goods-category.css
Normal file
@@ -0,0 +1,336 @@
|
|||||||
|
/**
|
||||||
|
* 头部背景
|
||||||
|
*/
|
||||||
|
.goods-top-bg {
|
||||||
|
height: calc(320rpx + var(--status-bar-height) + 5px);
|
||||||
|
/* #ifdef H5 */
|
||||||
|
height: 286rpx;
|
||||||
|
/* #endif */
|
||||||
|
background-color: #f5f5f5;
|
||||||
|
}
|
||||||
|
.goods-top-search-bg {
|
||||||
|
background-color: #f5f5f5;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 导航搜索、内容区域
|
||||||
|
*/
|
||||||
|
.nav-search {
|
||||||
|
padding-right: 250rpx;
|
||||||
|
/* #ifdef MP-ALIPAY */
|
||||||
|
padding-right: 255rpx;
|
||||||
|
padding-left: 80rpx;
|
||||||
|
/* #endif */
|
||||||
|
/* #ifdef H5 || MP-TOUTIAO || APP */
|
||||||
|
padding-right: 20rpx;
|
||||||
|
/* #endif */
|
||||||
|
/* #ifdef H5 */
|
||||||
|
padding-top: 20rpx !important;
|
||||||
|
/* #endif */
|
||||||
|
padding-bottom: 20rpx;
|
||||||
|
height: 64rpx;
|
||||||
|
z-index: 5;
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
.nav-more-top {
|
||||||
|
/* #ifdef H5 || APP */
|
||||||
|
top: 135rpx !important;
|
||||||
|
/* #endif */
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 左侧导航
|
||||||
|
*/
|
||||||
|
.left-nav {
|
||||||
|
width: 200rpx;
|
||||||
|
background-color: #f5f5f5;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
.left-nav .item {
|
||||||
|
height: 80rpx;
|
||||||
|
line-height: 80rpx;
|
||||||
|
padding: 0 10rpx;
|
||||||
|
background: #f5f5f5;
|
||||||
|
}
|
||||||
|
.left-nav .nav-active {
|
||||||
|
background: #fff;
|
||||||
|
font-weight: 500;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 右侧内容
|
||||||
|
*/
|
||||||
|
.right-container {
|
||||||
|
width: calc(100% - 200rpx);
|
||||||
|
height: 100%;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
background: #f5f5f5;
|
||||||
|
}
|
||||||
|
.content-item {
|
||||||
|
width: calc(100% / 3);
|
||||||
|
}
|
||||||
|
.content-item .content {
|
||||||
|
padding: 28rpx;
|
||||||
|
}
|
||||||
|
.content-item .text {
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
.content-item .icon {
|
||||||
|
width: 92rpx;
|
||||||
|
height: 92rpx;
|
||||||
|
}
|
||||||
|
.content-item.two-img .icon {
|
||||||
|
width: 104rpx;
|
||||||
|
height: 104rpx;
|
||||||
|
}
|
||||||
|
.content-item.two-img .content {
|
||||||
|
padding: 26rpx 0;
|
||||||
|
}
|
||||||
|
.model-one .content-item:nth-child(3n) {
|
||||||
|
border-right: 0;
|
||||||
|
}
|
||||||
|
.model-one .content .desc {
|
||||||
|
min-height: 52rpx;
|
||||||
|
line-height: 26rpx;
|
||||||
|
}
|
||||||
|
.model-one .content {
|
||||||
|
height: 240rpx;
|
||||||
|
}
|
||||||
|
.one-content image {
|
||||||
|
height: 120rpx;
|
||||||
|
}
|
||||||
|
.text-random-1,
|
||||||
|
.text-random-2,
|
||||||
|
.text-random-3,
|
||||||
|
.text-random-4,
|
||||||
|
.text-random-5,
|
||||||
|
.text-random-6,
|
||||||
|
.text-random-7,
|
||||||
|
.text-random-8,
|
||||||
|
.text-random-9 {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
.text-random-1::before,
|
||||||
|
.text-random-2::before,
|
||||||
|
.text-random-3::before,
|
||||||
|
.text-random-4::before,
|
||||||
|
.text-random-5::before,
|
||||||
|
.text-random-6::before,
|
||||||
|
.text-random-7::before,
|
||||||
|
.text-random-8::before,
|
||||||
|
.text-random-9::before {
|
||||||
|
content: '';
|
||||||
|
width: 126rpx;
|
||||||
|
height: 12rpx;
|
||||||
|
border-radius: 6rpx;
|
||||||
|
position: absolute;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
opacity: 0.6;
|
||||||
|
}
|
||||||
|
.text-random-1::before {
|
||||||
|
background: linear-gradient(90deg, #F2C3A5 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-2::before {
|
||||||
|
background: linear-gradient(90deg, #FF9BBB 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-3::before {
|
||||||
|
background: linear-gradient(90deg, #EAC5A9 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-4::before {
|
||||||
|
background: linear-gradient(90deg, #F7BEBE 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-5::before {
|
||||||
|
background: linear-gradient(90deg, #F2DC86 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-6::before {
|
||||||
|
background: linear-gradient(90deg, #98B7E8 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-7::before {
|
||||||
|
background: linear-gradient(90deg, #CD92F3 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-8::before {
|
||||||
|
background: linear-gradient(90deg, #5EEA7C 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
.text-random-9::before {
|
||||||
|
background: linear-gradient(90deg, #E67A7A 0%, rgba(255, 255, 255, 0) 100%);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 商品列表模式
|
||||||
|
*/
|
||||||
|
.category-content {
|
||||||
|
height: 100vh;
|
||||||
|
/* #ifdef MP-WEIXIN || MP-BAIDU || MP-QQ || MP-KUAISHOU || MP-ALIPAY || APP */
|
||||||
|
height: calc(100vh - 134rpx - var(--window-bottom));
|
||||||
|
/* #endif */
|
||||||
|
/* #ifdef H5 */
|
||||||
|
height: calc(100vh - 104rpx - var(--window-bottom));
|
||||||
|
/* #endif */
|
||||||
|
}
|
||||||
|
.category-content.goods-model {
|
||||||
|
padding-top: 182rpx;
|
||||||
|
}
|
||||||
|
.top-nav {
|
||||||
|
height: 182rpx;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
z-index: 4;
|
||||||
|
}
|
||||||
|
.top-nav-scroll {
|
||||||
|
width: calc(100% - 70rpx);
|
||||||
|
}
|
||||||
|
.top-nav .icon-content {
|
||||||
|
width: 92rpx;
|
||||||
|
height: 92rpx;
|
||||||
|
padding: 1px;
|
||||||
|
}
|
||||||
|
.top-nav-scroll .item:first-of-type {
|
||||||
|
padding-left: 16rpx;
|
||||||
|
}
|
||||||
|
.top-nav .item {
|
||||||
|
padding: 20rpx 4rpx;
|
||||||
|
}
|
||||||
|
.nav-list-more {
|
||||||
|
width: 100%;
|
||||||
|
max-height: 550rpx;
|
||||||
|
overflow-y: auto;
|
||||||
|
}
|
||||||
|
.nav-list-more image {
|
||||||
|
width: 92rpx;
|
||||||
|
height: 92rpx;
|
||||||
|
border-radius: 50%;
|
||||||
|
margin-bottom: 10rpx;
|
||||||
|
}
|
||||||
|
.nav-list-more .item {
|
||||||
|
width: 20%;
|
||||||
|
padding: 20rpx 0;
|
||||||
|
}
|
||||||
|
.goods-right-content {
|
||||||
|
width: calc(100% - 200rpx);
|
||||||
|
height: calc(100% - 182rpx);
|
||||||
|
top: 182rpx;
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
.right-content-actual .item {
|
||||||
|
padding-bottom: 20rpx;
|
||||||
|
}
|
||||||
|
.right-content-actual .item:not(:last-of-type) {
|
||||||
|
border-bottom: 1px solid #eee;
|
||||||
|
}
|
||||||
|
.right-content-actual .item .plugins-label-img {
|
||||||
|
border-top-left-radius: 10rpx;
|
||||||
|
}
|
||||||
|
.goods-right-content.category-one-subset-content {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.goods-list-top-nav {
|
||||||
|
position: sticky;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
z-index: 3;
|
||||||
|
}
|
||||||
|
.nav-sort-content .sort-item {
|
||||||
|
height: 80rpx;
|
||||||
|
line-height: 80rpx;
|
||||||
|
width: 20%;
|
||||||
|
}
|
||||||
|
.nav-sort-content .sort-item .sort-icon {
|
||||||
|
width: 26rpx;
|
||||||
|
height: 26rpx !important;
|
||||||
|
}
|
||||||
|
.goods-list .goods-img {
|
||||||
|
width: 160rpx;
|
||||||
|
height: 160rpx !important;
|
||||||
|
}
|
||||||
|
.goods-list .goods-base {
|
||||||
|
width: calc(100% - 200rpx);
|
||||||
|
padding-right: 20rpx;
|
||||||
|
}
|
||||||
|
.goods-list .goods-base-content {
|
||||||
|
min-height: 100rpx;
|
||||||
|
}
|
||||||
|
.goods-list .goods-base .simple-desc {
|
||||||
|
line-height: 30rpx;
|
||||||
|
min-height: 30rpx;
|
||||||
|
max-height: 58rpx;
|
||||||
|
}
|
||||||
|
.goods-list .goods-base .sales-price {
|
||||||
|
width: calc(100% - 140rpx);
|
||||||
|
}
|
||||||
|
.goods-list .goods-base .buy-number {
|
||||||
|
min-width: 32rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 底部导航
|
||||||
|
*/
|
||||||
|
.botton-nav {
|
||||||
|
width: calc(100% - 60rpx);
|
||||||
|
left: auto;
|
||||||
|
bottom: 20rpx;
|
||||||
|
z-index: 2;
|
||||||
|
margin-left: 20rpx;
|
||||||
|
box-shadow: 0rpx 4rpx 8rpx 0px rgba(0, 0, 0, 0.16);
|
||||||
|
line-height: 84rpx;
|
||||||
|
height: 84rpx;
|
||||||
|
}
|
||||||
|
.botton-nav .btn {
|
||||||
|
height: 70rpx;
|
||||||
|
line-height: 70rpx;
|
||||||
|
}
|
||||||
|
.botton-nav .cart .badge-icon {
|
||||||
|
top: -20rpx;
|
||||||
|
right: -2rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 购物车
|
||||||
|
*/
|
||||||
|
.cart-mask {
|
||||||
|
left: 0;
|
||||||
|
top: 0;
|
||||||
|
background: rgb(0, 0, 0, 0.6);
|
||||||
|
z-index: 5;
|
||||||
|
}
|
||||||
|
.cart-content {
|
||||||
|
left: auto;
|
||||||
|
bottom: 150rpx;
|
||||||
|
width: calc(100% - 40rpx);
|
||||||
|
z-index: 6;
|
||||||
|
max-width: calc(800px - 40rpx);
|
||||||
|
margin-left: 20rpx;
|
||||||
|
}
|
||||||
|
.cart-content .cart-list {
|
||||||
|
max-height: 60vh;
|
||||||
|
}
|
||||||
|
.cart-content .cart-list .goods-img {
|
||||||
|
width: 132rpx;
|
||||||
|
height: 132rpx !important;
|
||||||
|
}
|
||||||
|
.cart-content .cart-list .goods-base {
|
||||||
|
padding-right: 0;
|
||||||
|
padding-left: 24rpx;
|
||||||
|
}
|
||||||
|
.cart-content .cart-list .goods-base-content {
|
||||||
|
min-height: 60rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 无数据
|
||||||
|
*/
|
||||||
|
.no-data {
|
||||||
|
z-index: 101;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 隐藏滚动条
|
||||||
|
*/
|
||||||
|
scroll-view ::-webkit-scrollbar {
|
||||||
|
display: none;
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
color: transparent;
|
||||||
|
}
|
||||||
File diff suppressed because it is too large
Load Diff
665
pages/index/index1.vue
Normal file
665
pages/index/index1.vue
Normal file
@@ -0,0 +1,665 @@
|
|||||||
|
<template>
|
||||||
|
<view :class="theme_view">
|
||||||
|
<view :class="(plugins_mourning_data_is_app ? ' grayscale' : '') + (is_single_page == 1 ? ' single-page-top' : '')">
|
||||||
|
<!-- diy模式 -->
|
||||||
|
<block v-if="data_mode == 3">
|
||||||
|
<block v-if="(data_list || null) != null && (data_list.config || null) != null">
|
||||||
|
<componentDiy :propValue="data_list.config" :propDataId="data_list.id" :propKey="random_value" @onLocationBack="user_back_choice_location">
|
||||||
|
<!-- 底部内容 -->
|
||||||
|
<template slot="diy-bottom-content">
|
||||||
|
<!-- 结尾 -->
|
||||||
|
<component-bottom-line :propStatus="data_bottom_line_status"></component-bottom-line>
|
||||||
|
<!-- 版权信息 -->
|
||||||
|
<component-copyright></component-copyright>
|
||||||
|
</template>
|
||||||
|
<!-- 底部公共 -->
|
||||||
|
<template slot="diy-bottom-common">
|
||||||
|
<component-common ref="common" :propIsGrayscale="plugins_mourning_data_is_app"></component-common>
|
||||||
|
</template>
|
||||||
|
</componentDiy>
|
||||||
|
</block>
|
||||||
|
<block v-else>
|
||||||
|
<component-no-data propStatus="0" propPage="home"></component-no-data>
|
||||||
|
</block>
|
||||||
|
</block>
|
||||||
|
<!-- 自动和手动模式 -->
|
||||||
|
<block v-else>
|
||||||
|
<!-- 顶部内容、如果没有轮播和导航则使用矮的浮动导航背景样式,则使用高的背景样式 -->
|
||||||
|
<view v-if="load_status == 1" class="home-top-nav-content pr" :style="(banner_list.length > 0 || navigation.length > 0 ? top_content_bg_color : top_content_search_bg_color) + top_content_style">
|
||||||
|
<!-- 顶部背景图片 -->
|
||||||
|
<view class="pa top-0 left-0 right-0">
|
||||||
|
<image class="bg-img wh-auto" mode="widthFix" :src="static_url + 'nav-top.png'"></image>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 搜索 -->
|
||||||
|
<view v-if="common_app_is_header_nav_fixed == 1" :class="'search-fixed-seat ' + (common_app_is_enable_search == 1 ? 'nav-enable-search' : '')"></view>
|
||||||
|
<view :class="'pr ' + (common_app_is_header_nav_fixed == 1 ? 'search-content-fixed' : '')" :style="common_app_is_header_nav_fixed == 1 ? top_content_search_bg_color : ''">
|
||||||
|
<view :class="'search-content-fixed-content ' + (common_app_is_enable_search == 1 ? 'nav-enable-search' : '')" :style="(common_app_is_header_nav_fixed == 1 ? top_content_style : '') + (common_app_is_header_nav_fixed == 1 ? top_content_search_content_style : '')">
|
||||||
|
<view class="home-top-nav margin-bottom-sm pr padding-right-main">
|
||||||
|
<!-- 定位 -->
|
||||||
|
<view v-if="is_home_location_choice == 1" class="home-top-nav-location dis-inline-block va-m single-text cr-white pr bs-bb padding-left-main padding-right-lg">
|
||||||
|
<component-choice-location @onBack="user_back_choice_location"></component-choice-location>
|
||||||
|
</view>
|
||||||
|
<block v-else>
|
||||||
|
<!-- logo/标题 -->
|
||||||
|
<view class="home-top-nav-logo dis-inline-block va-m padding-left-main">
|
||||||
|
<block v-if="is_home_logo_use_text == 0 && (application_logo || null) != null">
|
||||||
|
<image :src="application_logo" mode="heightFix" class="home-top-nav-logo-image"></image>
|
||||||
|
</block>
|
||||||
|
<block v-else>
|
||||||
|
<view v-if="(application_title || null) != null" class="home-top-nav-logo-title cr-white single-text">{{ application_title }}</view>
|
||||||
|
</block>
|
||||||
|
</view>
|
||||||
|
</block>
|
||||||
|
<!-- #ifdef H5 || APP -->
|
||||||
|
<!-- 右上角icon列表 -->
|
||||||
|
<view v-if="(right_icon_list || null) != null && right_icon_list.length > 0" class="nav-top-right-icon fr">
|
||||||
|
<block v-for="(item, index) in right_icon_list">
|
||||||
|
<view class="item dis-inline-block cp pr" :data-value="item.url || ''" @tap="url_event">
|
||||||
|
<iconfont :name="item.icon" size="38rpx" color="#fff"></iconfont>
|
||||||
|
<view v-if="(item.badge || null) != null" class="badge-icon pa">
|
||||||
|
<component-badge :propNumber="item.badge"></component-badge>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</block>
|
||||||
|
</view>
|
||||||
|
<!-- #endif -->
|
||||||
|
</view>
|
||||||
|
<view v-if="common_app_is_enable_search == 1" class="search-content-input padding-horizontal-main">
|
||||||
|
<!-- 是否开启搜索框前面icon扫一扫 -->
|
||||||
|
<block v-if="is_home_search_scan == 1">
|
||||||
|
<component-search :propIsBtn="true" propSize="sm" :propPlaceholder="$t('customview.customview.726k7y')" propPlaceholderClass="cr-grey-c" propIconColor="#999" propBgColor="#fff"
|
||||||
|
<!-- #ifndef H5 -->
|
||||||
|
@onicon="search_icon_event" propIcon="icon-scan" :propIsIconOnEvent="true"
|
||||||
|
<!-- #endif -->
|
||||||
|
></component-search>
|
||||||
|
</block>
|
||||||
|
<block v-else>
|
||||||
|
<component-search :propIsBtn="true" propSize="sm" :propPlaceholder="$t('customview.customview.726k7y')" propPlaceholderClass="cr-grey-c" propIconColor="#999" propBgColor="#fff"></component-search>
|
||||||
|
</block>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 轮播 -->
|
||||||
|
<view class="banner-content padding-horizontal-main margin-top-xs" v-if="banner_list.length > 0">
|
||||||
|
<component-banner :propData="banner_list" @changeBanner="change_banner"></component-banner>
|
||||||
|
</view>
|
||||||
|
<!-- 导航 -->
|
||||||
|
<view v-if="navigation.length > 0" class="spacing-mt" :class="load_status == 1 && (common_shop_notice || null) != null ? '' : ' spacing-mb'">
|
||||||
|
<view class="padding-horizontal-main">
|
||||||
|
<view class="bg-white border-radius-main">
|
||||||
|
<component-icon-nav :propData="{ ...{ data: navigation }, ...{ random: random_value } }"></component-icon-nav>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 内容 -->
|
||||||
|
<view class="content padding-horizontal-main pr">
|
||||||
|
<!-- 商城公告 -->
|
||||||
|
<view v-if="load_status == 1 && (common_shop_notice || null) != null" class="notice">
|
||||||
|
<uni-notice-bar show-icon scrollable :text="common_shop_notice" background-color="transparent" color="#666" />
|
||||||
|
</view>
|
||||||
|
<!-- 推荐文章 -->
|
||||||
|
<view v-if="article_list.length > 0" class="article-list padding-main border-radius-main oh bg-white spacing-mb">
|
||||||
|
<view mode="aspectFit" class="new-icon va-m fl cp pr divider-r" data-value="/pages/article-category/article-category" @tap="url_event">
|
||||||
|
<text>{{ $t('index.index.t8bll8') }}</text
|
||||||
|
><text class="cr-red">{{ $t('index.index.t8bll9') }}</text>
|
||||||
|
</view>
|
||||||
|
<view class="right-content fr va-m">
|
||||||
|
<swiper :vertical="true" :autoplay="true" :circular="true" display-multiple-items="1" interval="3000">
|
||||||
|
<block v-for="(item, index) in article_list" :key="index">
|
||||||
|
<swiper-item class="single-text">
|
||||||
|
<text class="cr-base text-size-sm cp" :data-value="item.category_url" @tap="url_event">[{{ item.article_category_name }}]</text>
|
||||||
|
<text class="cr-base text-size-sm margin-left-xs cp" :style="(item.title_color || null) != null ? 'color:' + item.title_color + ' !important;' : ''" :data-value="item.url" @tap="url_event">{{ item.title }}</text>
|
||||||
|
</swiper-item>
|
||||||
|
</block>
|
||||||
|
</swiper>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 按照插件顺序渲染插件数据 -->
|
||||||
|
<block v-if="plugins_sort_list.length > 0">
|
||||||
|
<block v-for="(pv, pi) in plugins_sort_list" :key="pi">
|
||||||
|
<!-- 首页中间广告 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'homemiddleadv' && (plugins_homemiddleadv_data || null) != null && plugins_homemiddleadv_data.length > 0" class="plugins-homemiddleadv oh spacing-mb">
|
||||||
|
<view v-for="(item, index) in plugins_homemiddleadv_data" :key="index" class="item border-radius-main oh cp" :data-value="item.url || ''" @tap="url_event">
|
||||||
|
<image class="dis-block wh-auto border-radius-main" :src="item.images" mode="widthFix"> </image>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 限时秒杀 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'seckill' && (plugins_seckill_data || null) != null && (plugins_seckill_data.data || null) != null && (plugins_seckill_data.data.goods || null) != null && plugins_seckill_data.data.goods.length > 0" class="plugins-seckill-data border-radius-main spacing-mb bg-white" :style="'background-image: url(' + seckill_static_url + 'seckill-bg.png);'">
|
||||||
|
<view class="flex-row jc-sb align-c padding-top-main padding-horizontal-main">
|
||||||
|
<view class="flex-1">
|
||||||
|
<image class="dis-inline-block va-m icon" :src="plugins_seckill_data.data.home_title_icon" mode="widthFix"></image>
|
||||||
|
<view class="dis-inline-block va-m margin-left-sm">
|
||||||
|
<component-countdown :propHour="plugins_seckill_data.data.time.hours" :propMinute="plugins_seckill_data.data.time.minutes" :propSecond="plugins_seckill_data.data.time.seconds"></component-countdown>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<text data-value="/pages/plugins/seckill/index/index" @tap="url_event" class="arrow-right padding-right cr-grey text-size-xs cp">{{ $t('common.more') }}</text>
|
||||||
|
</view>
|
||||||
|
<component-goods-list :propData="{ style_type: 2, goods_list: plugins_seckill_data.data.goods }" :propLabel="plugins_label_data" :propCurrencySymbol="currency_symbol" :propIsCartParaCurve="true" propSource="index" :propOpenCart="false"></component-goods-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 活动配置-楼层顶部 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'activity' && (plugins_activity_data || null) != null">
|
||||||
|
<component-activity-list :propConfig="plugins_activity_data.base" :propData="plugins_activity_data.data" propLocation="0" :propLabel="plugins_label_data" :propCurrencySymbol="currency_symbol" :propIsCartParaCurve="true" propSource="index"></component-activity-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 门店 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'realstore' && (plugins_realstore_data || null) != null">
|
||||||
|
<view v-if="(plugins_realstore_data.base.home_data_list_title || null) != null" class="spacing-nav-title flex-row align-c jc-sb text-size-xs">
|
||||||
|
<text class="text-wrapper title-left-border single-text flex-1 flex-width padding-right-main">{{ plugins_realstore_data.base.home_data_list_title }}</text>
|
||||||
|
<text data-value="/pages/plugins/realstore/search/search" @tap="url_event" class="arrow-right padding-right cr-grey cp">{{ $t('common.more') }}</text>
|
||||||
|
</view>
|
||||||
|
<component-realstore-list :propData="{ ...{ data: plugins_realstore_data.data }, ...{ random: random_value } }"></component-realstore-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 多商户 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'shop' && (plugins_shop_data || null) != null">
|
||||||
|
<view v-if="(plugins_shop_data.base.home_data_list_title || null) != null" class="spacing-nav-title flex-row align-c jc-sb text-size-xs">
|
||||||
|
<text class="text-wrapper title-left-border single-text flex-1 flex-width padding-right-main">{{ plugins_shop_data.base.home_data_list_title }}</text>
|
||||||
|
<text data-value="/pages/plugins/shop/index/index" @tap="url_event" class="arrow-right padding-right cr-grey cp">{{ $t('common.more') }}</text>
|
||||||
|
</view>
|
||||||
|
<component-shop-list :propConfig="plugins_shop_data.base" :propData="{ ...{ data: plugins_shop_data.data }, ...{ random: random_value } }"></component-shop-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 组合搭配 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'binding' && (plugins_binding_data || null) != null">
|
||||||
|
<view v-if="(plugins_binding_data.base.home_data_list_title || null) != null" class="spacing-nav-title flex-row align-c jc-sb text-size-xs">
|
||||||
|
<text class="text-wrapper title-left-border single-text flex-1 flex-width padding-right-main">{{ plugins_binding_data.base.home_data_list_title }}</text>
|
||||||
|
<text data-value="/pages/plugins/binding/index/index" @tap="url_event" class="arrow-right padding-right cr-grey cp">{{ $t('common.more') }}</text>
|
||||||
|
</view>
|
||||||
|
<component-binding-list :propConfig="plugins_binding_data.base" :propData="{ ...{ data: plugins_binding_data.data }, ...{ random: random_value } }" :propCurrencySymbol="currency_symbol"></component-binding-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 博客-楼层顶部 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'blog' && (plugins_blog_data || null) != null">
|
||||||
|
<component-blog-list :propConfig="plugins_blog_data.base" :propData="plugins_blog_data.data" propLocation="0"></component-blog-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 魔方 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'magic' && (plugins_magic_data || null) != null">
|
||||||
|
<component-magic-list :propData="{ ...plugins_magic_data, ...{ random: random_value } }" :propCurrencySymbol="currency_symbol" :propLabel="plugins_label_data"></component-magic-list>
|
||||||
|
</view>
|
||||||
|
</block>
|
||||||
|
</block>
|
||||||
|
|
||||||
|
<!-- 楼层数据 -->
|
||||||
|
<block v-if="(data_list || null) != null && data_list.length > 0">
|
||||||
|
<!-- 数据模式0,1自动+手动、2拖拽 -->
|
||||||
|
<block v-if="data_mode == 2">
|
||||||
|
<!-- 引入拖拽数据模块 -->
|
||||||
|
<component-layout :propData="data_list"></component-layout>
|
||||||
|
</block>
|
||||||
|
<block v-else>
|
||||||
|
<!-- 自动+手动 -->
|
||||||
|
<view v-for="(floor, index) in data_list" :key="index" class="floor">
|
||||||
|
<view class="spacing-nav-title flex-row align-c jc-sb text-size-xs">
|
||||||
|
<view class="title-left">
|
||||||
|
<text class="text-wrapper title-left-border" :style="'color:' + (floor.bg_color || '#333') + ';'">{{ floor.name }}</text>
|
||||||
|
<text v-if="(floor.describe || null) != null" class="vice-name margin-left-lg cr-grey">{{ floor.describe }}</text>
|
||||||
|
</view>
|
||||||
|
<text :data-value="'/pages/goods-search/goods-search?category_id=' + floor.id" @tap="url_event" class="arrow-right padding-right cr-grey cp">{{ $t('common.more') }}</text>
|
||||||
|
</view>
|
||||||
|
<view class="floor-list wh-auto oh pr">
|
||||||
|
<block v-if="(floor.goods || null) != null && floor.goods.length > 0">
|
||||||
|
<component-goods-list :propData="{ style_type: 1, goods_list: floor.goods }" :propLabel="plugins_label_data" :propCurrencySymbol="currency_symbol" :propIsCartParaCurve="true" propSource="index"></component-goods-list>
|
||||||
|
</block>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</block>
|
||||||
|
</block>
|
||||||
|
|
||||||
|
<!-- 按照插件顺序渲染插件数据 -->
|
||||||
|
<block v-if="plugins_sort_list.length > 0">
|
||||||
|
<block v-for="(pv, pi) in plugins_sort_list" :key="pi">
|
||||||
|
<!-- 活动配置-楼层底部 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'activity' && (plugins_activity_data || null) != null">
|
||||||
|
<component-activity-list :propConfig="plugins_activity_data.base" :propData="plugins_activity_data.data" propLocation="1" :propLabel="plugins_label_data" :propCurrencySymbol="currency_symbol" propSource="index" :propOpenCart="false"></component-activity-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 博客-楼层底部 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'blog' && (plugins_blog_data || null) != null">
|
||||||
|
<component-blog-list :propConfig="plugins_blog_data.base" :propData="plugins_blog_data.data" propLocation="1"></component-blog-list>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!--- 底部购买记录 - 插件 -->
|
||||||
|
<view v-if="pv.plugins == 'salerecords' && (plugins_salerecords_data || null) != null && (plugins_salerecords_data.data || null) != null && plugins_salerecords_data.data.length > 0" class="plugins-salerecords bg-white border-radius-main padding-main spacing-mb">
|
||||||
|
<view class="spacing-nav-title flex-row align-c jc-sb text-size-xs">
|
||||||
|
<view class="title-left">
|
||||||
|
<text class="text-wrapper">{{ plugins_salerecords_data.base.home_bottom_title || $t('index.index.s5r784') }}</text>
|
||||||
|
<text v-if="(plugins_salerecords_data.base || null) != null && (plugins_salerecords_data.base.home_bottom_desc || null) != null" class="vice-name margin-left-sm cr-grey-9">{{ plugins_salerecords_data.base.home_bottom_desc }}</text>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view class="oh">
|
||||||
|
<swiper :vertical="true" :autoplay="true" :circular="true" :display-multiple-items="plugins_salerecords_data.data.length < 6 ? plugins_salerecords_data.data.length : 6" interval="3000" :style="plugins_salerecords_data.data.length < 6 ? 'height:' + plugins_salerecords_data.data.length * 84.33 + 'rpx;' : ''">
|
||||||
|
<block v-for="(item, index) in plugins_salerecords_data.data" :key="index">
|
||||||
|
<swiper-item>
|
||||||
|
<view class="item oh padding-vertical-main">
|
||||||
|
<view class="item-content single-text fl">
|
||||||
|
<image mode="widthFix" :src="item.user.avatar" class="va-m br"> </image>
|
||||||
|
<text class="margin-left-sm">{{ item.user.user_name_view }}</text>
|
||||||
|
<text v-if="(item.user.province || null) != null"><text class="padding-left-xs padding-right-xs">-</text>{{ item.user.province }}</text>
|
||||||
|
</view>
|
||||||
|
<view class="item-content fl">
|
||||||
|
<view :data-value="item.goods_url" @tap="url_event" class="cp single-text">
|
||||||
|
<image mode="widthFix" :src="item.images" class="va-m br"> </image>
|
||||||
|
<text class="margin-left-sm single-text">{{ item.title }}</text>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view class="item-content single-text fr tr cr-grey padding-top-xs">
|
||||||
|
{{ item.add_time }}
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</swiper-item>
|
||||||
|
</block>
|
||||||
|
</swiper>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
</block>
|
||||||
|
</block>
|
||||||
|
</view>
|
||||||
|
</block>
|
||||||
|
|
||||||
|
<!-- 提示信息 -->
|
||||||
|
<block v-if="load_status == 0">
|
||||||
|
<component-no-data :propStatus="data_list_loding_status" :propMsg="data_list_loding_msg" propPage="home" :propIsHeader="true"></component-no-data>
|
||||||
|
</block>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<!-- 页面已加载、模式 -->
|
||||||
|
<block v-if="load_status == 1 && data_mode != 3">
|
||||||
|
<!-- 结尾 -->
|
||||||
|
<component-bottom-line :propStatus="data_bottom_line_status"></component-bottom-line>
|
||||||
|
|
||||||
|
<!-- 版权信息 -->
|
||||||
|
<component-copyright></component-copyright>
|
||||||
|
|
||||||
|
<!-- 在线客服 -->
|
||||||
|
<component-online-service :propIsNav="true" :propIsBar="true" :propIsGrayscale="plugins_mourning_data_is_app"></component-online-service>
|
||||||
|
|
||||||
|
<!-- 快捷导航 -->
|
||||||
|
<component-quick-nav :propIsNav="true" :propIsBar="true" :propIsGrayscale="plugins_mourning_data_is_app"></component-quick-nav>
|
||||||
|
|
||||||
|
<!-- 公共 -->
|
||||||
|
<component-common ref="common" :propIsGrayscale="plugins_mourning_data_is_app"></component-common>
|
||||||
|
</block>
|
||||||
|
</view>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
const app = getApp();
|
||||||
|
import componentCommon from '@/components/common/common';
|
||||||
|
import componentSearch from '@/components/search/search';
|
||||||
|
import componentQuickNav from '@/components/quick-nav/quick-nav';
|
||||||
|
import componentIconNav from '@/components/icon-nav/icon-nav';
|
||||||
|
import componentBanner from '@/components/slider/slider';
|
||||||
|
import componentCountdown from '@/components/countdown/countdown';
|
||||||
|
import componentLayout from '@/components/layout/layout';
|
||||||
|
import componentBadge from '@/components/badge/badge';
|
||||||
|
import componentNoData from '@/components/no-data/no-data';
|
||||||
|
import componentBottomLine from '@/components/bottom-line/bottom-line';
|
||||||
|
import componentCopyright from '@/components/copyright/copyright';
|
||||||
|
import componentOnlineService from '@/components/online-service/online-service';
|
||||||
|
import componentActivityList from '@/components/activity-list/activity-list';
|
||||||
|
import componentBlogList from '@/components/blog-list/blog-list';
|
||||||
|
import componentRealstoreList from '@/components/realstore-list/realstore-list';
|
||||||
|
import componentShopList from '@/components/shop-list/shop-list';
|
||||||
|
import componentGoodsList from '@/components/goods-list/goods-list';
|
||||||
|
import componentBindingList from '@/components/binding-list/binding-list';
|
||||||
|
import componentMagicList from '@/components/magic-list/magic-list';
|
||||||
|
import componentDiy from '@/components/diy/diy';
|
||||||
|
import componentChoiceLocation from '@/components/choice-location/choice-location';
|
||||||
|
|
||||||
|
// 状态栏高度
|
||||||
|
var bar_height = parseInt(app.globalData.get_system_info('statusBarHeight', 0, true));
|
||||||
|
// #ifdef MP-TOUTIAO
|
||||||
|
bar_height = 0;
|
||||||
|
// #endif
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
theme_view: '',
|
||||||
|
theme_color: '',
|
||||||
|
common_static_url: '',
|
||||||
|
seckill_static_url: '',
|
||||||
|
static_url: '',
|
||||||
|
data_list_loding_status: 1,
|
||||||
|
data_list_loding_msg: '',
|
||||||
|
data_bottom_line_status: false,
|
||||||
|
load_status: 0,
|
||||||
|
currency_symbol: app.globalData.currency_symbol(),
|
||||||
|
is_home_search_scan: app.globalData.data.is_home_search_scan,
|
||||||
|
data_list: [],
|
||||||
|
banner_list: [],
|
||||||
|
navigation: [],
|
||||||
|
article_list: [],
|
||||||
|
cart_total: 0,
|
||||||
|
message_total: 0,
|
||||||
|
right_icon_list: [],
|
||||||
|
// 首页数据模式
|
||||||
|
data_mode: 0,
|
||||||
|
// 增加随机数,避免无法监听数据列表内部数据更新
|
||||||
|
random_value: 0,
|
||||||
|
// 基础配置
|
||||||
|
common_shop_notice: null,
|
||||||
|
common_app_is_enable_search: 0,
|
||||||
|
common_app_is_header_nav_fixed: 0,
|
||||||
|
common_app_is_online_service: 0,
|
||||||
|
// 顶部导航、名称、logo、定位
|
||||||
|
application_title: app.globalData.data.application_title,
|
||||||
|
application_logo: app.globalData.data.application_logo,
|
||||||
|
is_home_logo_use_text: app.globalData.data.is_home_logo_use_text,
|
||||||
|
is_home_location_choice: app.globalData.data.is_home_location_choice,
|
||||||
|
// 顶部+搜索样式配置
|
||||||
|
top_content_bg_color: '',
|
||||||
|
top_content_search_bg_color: '',
|
||||||
|
top_content_search_content_style: '',
|
||||||
|
// #ifdef MP
|
||||||
|
top_content_style: 'padding-top:' + (bar_height + 10) + 'px;',
|
||||||
|
// #endif
|
||||||
|
// #ifdef H5 || MP-TOUTIAO
|
||||||
|
top_content_style: 'padding-top:' + (bar_height + 14) + 'px;',
|
||||||
|
// #endif
|
||||||
|
// #ifdef APP
|
||||||
|
top_content_style: 'padding-top:' + bar_height + 'px;',
|
||||||
|
// #endif
|
||||||
|
// 是否单页预览
|
||||||
|
is_single_page: app.globalData.is_current_single_page() || 0,
|
||||||
|
// 轮播滚动时,背景色替换
|
||||||
|
slider_bg: null,
|
||||||
|
// 插件顺序列表
|
||||||
|
plugins_sort_list: [],
|
||||||
|
// 限时秒杀插件
|
||||||
|
plugins_seckill_data: null,
|
||||||
|
// 购买记录插件
|
||||||
|
plugins_salerecords_data: null,
|
||||||
|
// 活动配置插件
|
||||||
|
plugins_activity_data: null,
|
||||||
|
// 标签插件
|
||||||
|
plugins_label_data: null,
|
||||||
|
// 首页中间广告插件
|
||||||
|
plugins_homemiddleadv_data: null,
|
||||||
|
// 哀悼灰度插件
|
||||||
|
plugins_mourning_data_is_app: app.globalData.is_app_mourning(),
|
||||||
|
// 标签插件
|
||||||
|
plugins_blog_data: null,
|
||||||
|
// 门店插件
|
||||||
|
plugins_realstore_data: null,
|
||||||
|
// 多商户插件
|
||||||
|
plugins_shop_data: null,
|
||||||
|
// 组合搭配插件
|
||||||
|
plugins_binding_data: null,
|
||||||
|
// 魔方插件
|
||||||
|
plugins_magic_data: null,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
components: {
|
||||||
|
componentCommon,
|
||||||
|
componentSearch,
|
||||||
|
componentQuickNav,
|
||||||
|
componentIconNav,
|
||||||
|
componentBanner,
|
||||||
|
componentCountdown,
|
||||||
|
componentLayout,
|
||||||
|
componentBadge,
|
||||||
|
componentNoData,
|
||||||
|
componentBottomLine,
|
||||||
|
componentCopyright,
|
||||||
|
componentOnlineService,
|
||||||
|
componentActivityList,
|
||||||
|
componentBlogList,
|
||||||
|
componentRealstoreList,
|
||||||
|
componentShopList,
|
||||||
|
componentGoodsList,
|
||||||
|
componentBindingList,
|
||||||
|
componentMagicList,
|
||||||
|
componentDiy,
|
||||||
|
componentChoiceLocation,
|
||||||
|
},
|
||||||
|
|
||||||
|
onLoad(params) {
|
||||||
|
// 调用公共事件方法
|
||||||
|
app.globalData.page_event_onload_handle(params);
|
||||||
|
},
|
||||||
|
|
||||||
|
onShow() {
|
||||||
|
// 调用公共事件方法
|
||||||
|
app.globalData.page_event_onshow_handle();
|
||||||
|
|
||||||
|
// 数据加载
|
||||||
|
this.init();
|
||||||
|
|
||||||
|
// 初始化配置
|
||||||
|
this.init_config();
|
||||||
|
|
||||||
|
// 公共onshow事件
|
||||||
|
if ((this.$refs.common || null) != null) {
|
||||||
|
this.$refs.common.on_show({object: this, method: 'init'});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 设置顶部导航的默认颜色
|
||||||
|
this.set_navigation_bar_color();
|
||||||
|
},
|
||||||
|
|
||||||
|
// 下拉刷新
|
||||||
|
onPullDownRefresh() {
|
||||||
|
if (this.data_list_loding_status === 1) {
|
||||||
|
uni.stopPullDownRefresh();
|
||||||
|
} else {
|
||||||
|
this.init();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
methods: {
|
||||||
|
// 初始化配置
|
||||||
|
init_config(status) {
|
||||||
|
if ((status || false) == true) {
|
||||||
|
this.setData({
|
||||||
|
currency_symbol: app.globalData.get_config('currency_symbol'),
|
||||||
|
common_shop_notice: app.globalData.get_config('config.common_shop_notice'),
|
||||||
|
common_app_is_enable_search: app.globalData.get_config('config.common_app_is_enable_search'),
|
||||||
|
common_app_is_header_nav_fixed: app.globalData.get_config('config.common_app_is_header_nav_fixed'),
|
||||||
|
common_app_is_online_service: app.globalData.get_config('config.common_app_is_online_service'),
|
||||||
|
application_title: app.globalData.get_application_title(),
|
||||||
|
application_logo: app.globalData.get_application_logo(),
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
app.globalData.is_config(this, 'init_config');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
// 获取数据
|
||||||
|
init(params = {}) {
|
||||||
|
// 还没有数据则读取缓存
|
||||||
|
var cache_key = app.globalData.data.cache_index_data_key;
|
||||||
|
if (this.load_status == 0) {
|
||||||
|
// 本地缓存数据
|
||||||
|
var upd_data = uni.getStorageSync(cache_key) || null;
|
||||||
|
if (upd_data != null) {
|
||||||
|
// 先使用缓存数据展示
|
||||||
|
this.setData(upd_data);
|
||||||
|
|
||||||
|
// 初始化返回公共处理
|
||||||
|
this.init_result_common_handle();
|
||||||
|
|
||||||
|
// 已有本地缓存则直接取远程有效数据(默认首次取的是远程缓存数据)
|
||||||
|
params['is_cache'] = 0;
|
||||||
|
|
||||||
|
// 设置顶部导航的默认颜色
|
||||||
|
this.set_navigation_bar_color();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// 已有本地缓存则直接取远程有效数据(默认首次取的是远程缓存数据)
|
||||||
|
params['is_cache'] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 网络检查
|
||||||
|
if ((params || null) == null || (params.loading || 0) == 0) {
|
||||||
|
app.globalData.network_type_handle(this, 'init', params);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 没有缓存数据则开启加载层
|
||||||
|
if (upd_data == null) {
|
||||||
|
this.setData({
|
||||||
|
data_list_loding_status: 1,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
// 请求远程数据
|
||||||
|
uni.request({
|
||||||
|
url: app.globalData.get_request_url('index', 'index'),
|
||||||
|
method: 'POST',
|
||||||
|
data: params,
|
||||||
|
dataType: 'json',
|
||||||
|
success: (res) => {
|
||||||
|
uni.stopPullDownRefresh();
|
||||||
|
// 数据处理
|
||||||
|
var data = res.data.data;
|
||||||
|
if (res.data.code == 0) {
|
||||||
|
var data_list = data.data_list || null;
|
||||||
|
var upd_data = {
|
||||||
|
random_value: Math.random(),
|
||||||
|
data_bottom_line_status: true,
|
||||||
|
banner_list: data.banner_list || [],
|
||||||
|
navigation: data.navigation || [],
|
||||||
|
article_list: data.article_list || [],
|
||||||
|
data_mode: data.data_mode || 0,
|
||||||
|
data_list: data_list,
|
||||||
|
cart_total: data.cart_total.buy_number || 0,
|
||||||
|
message_total: parseInt(data.message_total || 0),
|
||||||
|
right_icon_list: data.right_icon_list || [],
|
||||||
|
data_list_loding_status: data_list == null || data_list.length == 0 ? 0 : 3,
|
||||||
|
plugins_sort_list: data.plugins_sort_list || [],
|
||||||
|
plugins_seckill_data: data.plugins_seckill_data || null,
|
||||||
|
plugins_salerecords_data: (data.plugins_salerecords_data || null) == null || data.plugins_salerecords_data.length <= 0 ? null : data.plugins_salerecords_data,
|
||||||
|
plugins_activity_data: (data.plugins_activity_data || null) == null || data.plugins_activity_data.length <= 0 ? null : data.plugins_activity_data,
|
||||||
|
plugins_label_data: (data.plugins_label_data || null) == null || (data.plugins_label_data.base || null) == null || (data.plugins_label_data.data || null) == null || data.plugins_label_data.data.length <= 0 ? null : data.plugins_label_data,
|
||||||
|
plugins_homemiddleadv_data: (data.plugins_homemiddleadv_data || null) == null || data.plugins_homemiddleadv_data.length <= 0 ? null : data.plugins_homemiddleadv_data,
|
||||||
|
plugins_mourning_data_is_app: parseInt(data.plugins_mourning_data || 0) == 1,
|
||||||
|
plugins_blog_data: data.plugins_blog_data || null,
|
||||||
|
plugins_realstore_data: data.plugins_realstore_data || null,
|
||||||
|
plugins_shop_data: data.plugins_shop_data || null,
|
||||||
|
plugins_binding_data: data.plugins_binding_data || null,
|
||||||
|
plugins_magic_data: data.plugins_magic_data || null,
|
||||||
|
};
|
||||||
|
// 如果开启了哀悼灰色则不固定导航
|
||||||
|
if (upd_data.plugins_mourning_data_is_app == 1) {
|
||||||
|
upd_data['common_app_is_header_nav_fixed'] = 0;
|
||||||
|
}
|
||||||
|
this.setData(upd_data);
|
||||||
|
|
||||||
|
// 存储缓存
|
||||||
|
uni.setStorageSync(cache_key, upd_data);
|
||||||
|
|
||||||
|
// 设置顶部导航的默认颜色
|
||||||
|
this.set_navigation_bar_color();
|
||||||
|
|
||||||
|
// 是否需要重新加载数据
|
||||||
|
if (parseInt(data.is_result_data_cache || 0) == 1) {
|
||||||
|
this.init({ is_cache: 0 });
|
||||||
|
} else {
|
||||||
|
// 购物车导航角标
|
||||||
|
app.globalData.set_tab_bar_badge('cart', this.cart_total);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this.setData({
|
||||||
|
data_list_loding_status: 0,
|
||||||
|
data_list_loding_msg: res.data.msg,
|
||||||
|
data_bottom_line_status: true,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 初始化返回公共处理
|
||||||
|
this.init_result_common_handle();
|
||||||
|
},
|
||||||
|
fail: () => {
|
||||||
|
// 轮播数据处理
|
||||||
|
if (this.load_status == 0 || (this.top_content_search_bg_color || null) == null) {
|
||||||
|
this.change_banner(app.globalData.get_theme_color());
|
||||||
|
}
|
||||||
|
|
||||||
|
uni.stopPullDownRefresh();
|
||||||
|
this.setData({
|
||||||
|
data_list_loding_status: 2,
|
||||||
|
data_list_loding_msg: this.$t('common.internet_error_tips'),
|
||||||
|
data_bottom_line_status: true,
|
||||||
|
load_status: 1,
|
||||||
|
});
|
||||||
|
},
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
// 设置顶部导航的默认颜色
|
||||||
|
set_navigation_bar_color() {
|
||||||
|
if(this.data_mode == 3) {
|
||||||
|
app.globalData.set_navigation_bar_color(parseInt(app.globalData.get_key_data(this.data_list, 'config.header.com_data.style.function_buttons_type', 0)) == 1);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
// 初始化返回公共处理
|
||||||
|
init_result_common_handle() {
|
||||||
|
var theme_view = app.globalData.get_theme_value_view();
|
||||||
|
var theme_color = app.globalData.get_theme_color();
|
||||||
|
var common_static_url = app.globalData.get_static_url('common');
|
||||||
|
var seckill_static_url = app.globalData.get_static_url('seckill', true) + 'app/';
|
||||||
|
var static_url = app.globalData.get_static_url('home');
|
||||||
|
|
||||||
|
// 轮播数据处理
|
||||||
|
if (this.load_status == 0 || (this.top_content_search_bg_color || null) == null) {
|
||||||
|
var color = this.banner_list && this.banner_list.length > 0 && (this.banner_list[0]['bg_color'] || null) != null ? this.banner_list[0]['bg_color'] : theme_color;
|
||||||
|
this.change_banner(color);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 公共数据
|
||||||
|
this.setData({
|
||||||
|
top_content_search_content_style: 'background-image: url("' + static_url + 'nav-top.png");',
|
||||||
|
theme_view: theme_view,
|
||||||
|
theme_color: theme_color,
|
||||||
|
common_static_url: common_static_url,
|
||||||
|
seckill_static_url: seckill_static_url,
|
||||||
|
static_url: static_url,
|
||||||
|
load_status: 1,
|
||||||
|
});
|
||||||
|
|
||||||
|
// 分享菜单处理、延时执行,确保基础数据已加载完成
|
||||||
|
setTimeout(function () {
|
||||||
|
app.globalData.page_share_handle();
|
||||||
|
}, 3000);
|
||||||
|
},
|
||||||
|
|
||||||
|
// 选择用户地理位置回调
|
||||||
|
user_back_choice_location(e) {
|
||||||
|
// 重新刷新数据
|
||||||
|
this.init();
|
||||||
|
},
|
||||||
|
|
||||||
|
// url事件
|
||||||
|
url_event(e) {
|
||||||
|
app.globalData.url_event(e);
|
||||||
|
},
|
||||||
|
|
||||||
|
// 轮播改变、背景色处理
|
||||||
|
change_banner(color) {
|
||||||
|
if ((color || null) == null) {
|
||||||
|
color = this.theme_color;
|
||||||
|
}
|
||||||
|
this.setData({
|
||||||
|
top_content_bg_color: 'background: linear-gradient(180deg, ' + color + ' 0%, #f5f5f5 80%);',
|
||||||
|
top_content_search_bg_color: 'background: linear-gradient(180deg, ' + color + ' 0%, #f5f5f5 300%);',
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
// 搜索icon扫码事件
|
||||||
|
search_icon_event(e) {
|
||||||
|
app.globalData.scan_handle();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
<style>
|
||||||
|
@import './index.css';
|
||||||
|
</style>
|
||||||
@@ -255,7 +255,8 @@
|
|||||||
var user = app.globalData.get_user_info(this, 'init');
|
var user = app.globalData.get_user_info(this, 'init');
|
||||||
if (user != false) {
|
if (user != false) {
|
||||||
this.setData({
|
this.setData({
|
||||||
pay_url: app.globalData.get_request_url('pay', 'order'),
|
// pay_url: app.globalData.get_request_url('pay', 'order'),
|
||||||
|
pay_url: app.globalData.get_request_url('getpayment', 'xo'),
|
||||||
qrcode_url: app.globalData.get_request_url('paycheck', 'order'),
|
qrcode_url: app.globalData.get_request_url('paycheck', 'order'),
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
// webpack配置
|
// webpack配置
|
||||||
configureWebpack: {
|
configureWebpack: {
|
||||||
// 关闭 webpack 的性能提示
|
// 关闭 webpack 的性能提示
|
||||||
performance: {
|
performance: {
|
||||||
hints: false
|
hints: false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user