yzx 3 months ago
parent
commit
a5f85cf4b5
100 changed files with 21 additions and 12029 deletions
  1. 2 2
      App.vue
  2. 2 2
      common/request.js
  3. 2 20
      pages.json
  4. 1 1
      pages/auth/login.vue
  5. 3 3
      pages/index/index.vue
  6. 0 0
      unpackage/dist/build/mp-weixin/app.js
  7. 1 1
      unpackage/dist/build/mp-weixin/app.json
  8. 1 1
      unpackage/dist/build/mp-weixin/common/request.js
  9. 2 2
      unpackage/dist/build/mp-weixin/miniprogram_npm/@tencentcloud/call-uikit-wechat/index.js
  10. 1 1
      unpackage/dist/build/mp-weixin/miniprogram_npm/tim-wx-sdk/index.js
  11. 1 1
      unpackage/dist/build/mp-weixin/miniprogram_npm/trtc-wx-sdk/index.js
  12. 1 1
      unpackage/dist/build/mp-weixin/miniprogram_npm/tsignaling-wx/index.js
  13. 1 1
      unpackage/dist/build/mp-weixin/miniprogram_npm/tuicall-engine-wx/index.js
  14. 1 1
      unpackage/dist/build/mp-weixin/pages/auth/login.wxml
  15. 0 0
      unpackage/dist/build/mp-weixin/pages/index/index.js
  16. 0 0
      unpackage/dist/build/mp-weixin/pages/index/index.wxml
  17. 0 0
      unpackage/dist/build/mp-weixin/pages/index/index.wxss
  18. 0 0
      unpackage/dist/build/mp-weixin/pages_company/index.js
  19. 1 1
      unpackage/dist/build/mp-weixin/pages_company/index.wxml
  20. 0 0
      unpackage/dist/build/mp-weixin/pages_course/video.js
  21. 0 0
      unpackage/dist/build/mp-weixin/pages_course/video.wxml
  22. 0 0
      unpackage/dist/build/mp-weixin/pages_course/video.wxss
  23. 1 2
      unpackage/dist/build/mp-weixin/project.config.json
  24. 0 7
      unpackage/dist/dev/mp-weixin/api/adv.js
  25. 0 15
      unpackage/dist/dev/mp-weixin/api/article.js
  26. 0 27
      unpackage/dist/dev/mp-weixin/api/common.js
  27. 0 15
      unpackage/dist/dev/mp-weixin/api/companyUser.js
  28. 0 19
      unpackage/dist/dev/mp-weixin/api/coupon.js
  29. 0 47
      unpackage/dist/dev/mp-weixin/api/course.js
  30. 0 11
      unpackage/dist/dev/mp-weixin/api/courseOrder.js
  31. 0 7
      unpackage/dist/dev/mp-weixin/api/department.js
  32. 0 11
      unpackage/dist/dev/mp-weixin/api/disease.js
  33. 0 27
      unpackage/dist/dev/mp-weixin/api/doctor.js
  34. 0 15
      unpackage/dist/dev/mp-weixin/api/doctorArticle.js
  35. 0 23
      unpackage/dist/dev/mp-weixin/api/drugReport.js
  36. 0 15
      unpackage/dist/dev/mp-weixin/api/follow.js
  37. 0 31
      unpackage/dist/dev/mp-weixin/api/healthRecords.js
  38. 0 19
      unpackage/dist/dev/mp-weixin/api/healthTongue.js
  39. 0 11
      unpackage/dist/dev/mp-weixin/api/hospital.js
  40. 0 43
      unpackage/dist/dev/mp-weixin/api/index.js
  41. 0 63
      unpackage/dist/dev/mp-weixin/api/inquiryOrder.js
  42. 0 35
      unpackage/dist/dev/mp-weixin/api/integral.js
  43. 0 19
      unpackage/dist/dev/mp-weixin/api/package.js
  44. 0 47
      unpackage/dist/dev/mp-weixin/api/packageOrder.js
  45. 0 23
      unpackage/dist/dev/mp-weixin/api/patient.js
  46. 0 11
      unpackage/dist/dev/mp-weixin/api/prescribe.js
  47. 0 27
      unpackage/dist/dev/mp-weixin/api/storeAfterSales.js
  48. 0 47
      unpackage/dist/dev/mp-weixin/api/storeOrder.js
  49. 0 27
      unpackage/dist/dev/mp-weixin/api/test.js
  50. 0 35
      unpackage/dist/dev/mp-weixin/api/user.js
  51. 0 31
      unpackage/dist/dev/mp-weixin/api/userAddress.js
  52. 0 11
      unpackage/dist/dev/mp-weixin/api/userVipOrder.js
  53. 0 282
      unpackage/dist/dev/mp-weixin/app.js
  54. 0 206
      unpackage/dist/dev/mp-weixin/app.json
  55. 0 501
      unpackage/dist/dev/mp-weixin/app.wxss
  56. 0 35
      unpackage/dist/dev/mp-weixin/common/assets.js
  57. 0 63
      unpackage/dist/dev/mp-weixin/common/request.js
  58. 0 7213
      unpackage/dist/dev/mp-weixin/common/vendor.js
  59. 0 71
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.js
  60. 0 4
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.json
  61. 0 1
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.wxml
  62. 0 73
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.wxss
  63. 0 94
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.js
  64. 0 6
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.json
  65. 0 1
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.wxml
  66. 0 110
      unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.wxss
  67. 0 20
      unpackage/dist/dev/mp-weixin/components/Loading.js
  68. 0 4
      unpackage/dist/dev/mp-weixin/components/Loading.json
  69. 0 1
      unpackage/dist/dev/mp-weixin/components/Loading.wxml
  70. 0 26
      unpackage/dist/dev/mp-weixin/components/Loading.wxss
  71. 0 94
      unpackage/dist/dev/mp-weixin/components/Menu.js
  72. 0 4
      unpackage/dist/dev/mp-weixin/components/Menu.json
  73. 0 1
      unpackage/dist/dev/mp-weixin/components/Menu.wxml
  74. 0 96
      unpackage/dist/dev/mp-weixin/components/Menu.wxss
  75. 0 13
      unpackage/dist/dev/mp-weixin/miniprogram_npm/@tencentcloud/call-uikit-wechat/index.js
  76. 0 1
      unpackage/dist/dev/mp-weixin/miniprogram_npm/@tencentcloud/call-uikit-wechat/index.js.map
  77. 0 7
      unpackage/dist/dev/mp-weixin/miniprogram_npm/tim-wx-sdk/index.js
  78. 0 0
      unpackage/dist/dev/mp-weixin/miniprogram_npm/tim-wx-sdk/index.js.map
  79. 0 7
      unpackage/dist/dev/mp-weixin/miniprogram_npm/trtc-wx-sdk/index.js
  80. 0 0
      unpackage/dist/dev/mp-weixin/miniprogram_npm/trtc-wx-sdk/index.js.map
  81. 0 7
      unpackage/dist/dev/mp-weixin/miniprogram_npm/tsignaling-wx/index.js
  82. 0 0
      unpackage/dist/dev/mp-weixin/miniprogram_npm/tsignaling-wx/index.js.map
  83. 0 7
      unpackage/dist/dev/mp-weixin/miniprogram_npm/tuicall-engine-wx/index.js
  84. 0 0
      unpackage/dist/dev/mp-weixin/miniprogram_npm/tuicall-engine-wx/index.js.map
  85. 0 50
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/README.md
  86. 0 927
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.js
  87. 0 11
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.json
  88. 0 52
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.wxml
  89. 0 25
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.wxss
  90. 0 108
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.js
  91. 0 4
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.json
  92. 0 106
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.wxml
  93. 0 258
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.wxss
  94. 0 155
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.js
  95. 0 4
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.json
  96. 0 118
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.wxml
  97. 0 253
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.wxss
  98. 0 112
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/groupCalling/groupCalling.js
  99. 0 4
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/groupCalling/groupCalling.json
  100. 0 135
      unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/groupCalling/groupCalling.wxml

+ 2 - 2
App.vue

@@ -23,8 +23,8 @@
  // #endif
  
 import {  TUIConversationServer, TUIProfileServer } from "@/pages/TUIKit/TUICore/server";
-// var appId=1400825410
-var appId=1600023785;
+var appId=1400825410
+// var appId=1600023785;
 // 创建 sdk 实例
 uni.$TUIKit = TIM.create({
   SDKAppID: appId,

+ 2 - 2
common/request.js

@@ -3,9 +3,9 @@ export default class Request {
 	http(router, data = {}, method,contentType,url) {
 		let that = this;
 		// let path = 'http://127.0.0.1:8113';
-		// var path=uni.getStorageSync('requestPath')
+		var path=uni.getStorageSync('requestPath')
 		// var path = 'https://userapp.his.cdwjyyh.com';
-		var path = 'https://app.rtys.cdwjyyh.com';
+		// var path = 'https://app.rtys.cdwjyyh.com';
 		let token="";
 		if(url!=null){
 			path= url;

+ 2 - 20
pages.json

@@ -1175,14 +1175,6 @@
 				 	"style": {
 				 		"navigationBarTitleText": "健康管家"
 				 	}
-				 },{
-				 	"path": "bindCompanyUser",
-				 	"style": {
-				 		"navigationBarTitleText": "绑定",
-				 		"enablePullDownRefresh": false,
-				 		"navigationBarBackgroundColor":"#ffffff",
-				 		"navigationBarTextStyle":"black"
-				 	}
 				 }
 			]
 		},
@@ -1306,18 +1298,8 @@
 				        "navigationBarTitleText": "快递信息"
 				    }
 				    
-				},
-				{
-				    "path" : "bindInfo",
-				    "style" :                                                                                    
-				    {
-				        "navigationBarTitleText" : "",
-				        "enablePullDownRefresh": false,
-				        "navigationBarBackgroundColor":"#f7f7f7",
-				        "navigationBarTextStyle":"black"
-				    }
-				    
 				}
+				
 				 
 			]
 		},
@@ -1346,7 +1328,7 @@
 	],
 	"globalStyle": {
 		"navigationBarTextStyle": "white",
-		"navigationBarTitleText": "彩虹惠医互联网医院",
+		"navigationBarTitleText": "御君方互联网医院",
 		"navigationBarBackgroundColor": "#C39A58",
 		"backgroundColor": "#ffffff"
 	},

+ 1 - 1
pages/auth/login.vue

@@ -6,7 +6,7 @@
 					<view class="logo-img">
 						<image src="https://cos.his.cdwjyyh.com/fs/20240423/1287b2bf7c944538905f5092e8ff7db9.png"></image>
 					</view>
-					<view class="title">彩虹惠医互联网医院</view>
+					<view class="title">御君方互联网医院</view>
 				</view>
 				<view class="login-notice">为了提供更优质的服务,请先登录</view>
 				<view class="btns">

+ 3 - 3
pages/index/index.vue

@@ -7,7 +7,7 @@
 			<view class="top-box" :style="{ background: bg }" >
 				<view class="status_bar" :style="{height: statusBarHeight}"></view>
 				<view class="top-title">
-					<view class="name" :style="{ color: titleColor }">彩虹惠医互联网医院</view>
+					<view class="name" :style="{ color: titleColor }">御君方互联网医院</view>
 					<view class="desc-box" >
 						<image v-if="!isTop" src="../../static/images/dui.png"></image>
 						<image v-if="isTop" src="../../static/images/dui1.png"></image>
@@ -349,7 +349,7 @@
 		onShareAppMessage(res) {
 			if(this.$isLogin()){
 				return {
-					title: "彩虹惠医互联网医院",
+					title: "御君方互联网医院",
 					path: '/pages/index/index',
 					imageUrl: 'https://hos-1309931967.cos.ap-chongqing.myqcloud.com/fs/20230106/6b459adfb1004c1a96219bcdf07e337c.png' //分享图标,路径可以是本地文件路径、代码包文件路径或者网络图片路径.支持PNG及JPG。显示图片长宽比是 5:4
 				}
@@ -360,7 +360,7 @@
 		onShareTimeline(res) {
 			if(this.utils.isLogin()){
 				return {
-					title: "彩虹惠医互联网医院",
+					title: "御君方互联网医院",
 					imageUrl: 'https://hos-1309931967.cos.ap-chongqing.myqcloud.com/fs/20230106/6b459adfb1004c1a96219bcdf07e337c.png' //分享图标,路径可以是本地文件路径、代码包文件路径或者网络图片路径.支持PNG及JPG。显示图片长宽比是 5:4
 				}
 			}

File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/app.js


+ 1 - 1
unpackage/dist/build/mp-weixin/app.json

@@ -166,7 +166,7 @@
   ],
   "window": {
     "navigationBarTextStyle": "white",
-    "navigationBarTitleText": "彩虹惠医互联网医院",
+    "navigationBarTitleText": "御君方互联网医院",
     "navigationBarBackgroundColor": "#C39A58",
     "backgroundColor": "#ffffff"
   },

+ 1 - 1
unpackage/dist/build/mp-weixin/common/request.js

@@ -1 +1 @@
-"use strict";var e=require("./vendor.js");exports.Request=class{http(t,n={},a,o,r){var s="https://app.rtys.cdwjyyh.com";let d="";return null!=r?(s=r,d=e.index.getStorageSync("AppTokenmini_RTCourse")):(e.index.setStorageSync("requestPath",s),d=e.index.getStorageSync("AppToken")),new Promise(((r,i)=>{let l=e.index.getStorageSync("CompanyUserToken");var p="application/x-www-form-urlencoded";null!=o&&(p=o),e.index.request({header:{"Content-Type":p,AppToken:d,CompanyUserToken:l},url:`${s}${t}`,data:n,method:a,success:t=>{if(401==t.data.code){let n=getCurrentPages(),a=n[n.length-1];return console.log(a),null!=a&&"pages/auth/login"==a.route?void r(t.data):void e.index.navigateTo({url:"/pages/auth/login",success:()=>{},fail:()=>{}})}t.data.token&&e.index.setStorageSync("AppToken",t.data.token),r(t.data)},fail:e=>{},complete:e=>{if(401==e.data.code)return!1}})}))}};
+"use strict";var e=require("./vendor.js");exports.Request=class{http(t,n={},a,o,r){var s=e.index.getStorageSync("requestPath");let d="";return null!=r?(s=r,d=e.index.getStorageSync("AppTokenmini_RTCourse")):(e.index.setStorageSync("requestPath",s),d=e.index.getStorageSync("AppToken")),new Promise(((r,i)=>{let l=e.index.getStorageSync("CompanyUserToken");var u="application/x-www-form-urlencoded";null!=o&&(u=o),e.index.request({header:{"Content-Type":u,AppToken:d,CompanyUserToken:l},url:`${s}${t}`,data:n,method:a,success:t=>{if(401==t.data.code){let n=getCurrentPages(),a=n[n.length-1];return console.log(a),null!=a&&"pages/auth/login"==a.route?void r(t.data):void e.index.navigateTo({url:"/pages/auth/login",success:()=>{},fail:()=>{}})}t.data.token&&e.index.setStorageSync("AppToken",t.data.token),r(t.data)},fail:e=>{},complete:e=>{if(401==e.data.code)return!1}})}))}};

+ 2 - 2
unpackage/dist/build/mp-weixin/miniprogram_npm/@tencentcloud/call-uikit-wechat/index.js

@@ -4,10 +4,10 @@ var __DEFINE__ = function(modId, func, req) { var m = { exports: {}, _tempexport
 var __REQUIRE__ = function(modId, source) { if(!__MODS__[modId]) return require(source); if(!__MODS__[modId].status) { var m = __MODS__[modId].m; m._exports = m._tempexports; var desp = Object.getOwnPropertyDescriptor(m, "exports"); if (desp && desp.configurable) Object.defineProperty(m, "exports", { set: function (val) { if(typeof val === "object" && val !== m._exports) { m._exports.__proto__ = val.__proto__; Object.keys(val).forEach(function (k) { m._exports[k] = val[k]; }); } m._tempexports = val }, get: function () { return m._tempexports; } }); __MODS__[modId].status = 1; __MODS__[modId].func(__MODS__[modId].req, m, m.exports); } return __MODS__[modId].m.exports; };
 var __REQUIRE_WILDCARD__ = function(obj) { if(obj && obj.__esModule) { return obj; } else { var newObj = {}; if(obj != null) { for(var k in obj) { if (Object.prototype.hasOwnProperty.call(obj, k)) newObj[k] = obj[k]; } } newObj.default = obj; return newObj; } };
 var __REQUIRE_DEFAULT__ = function(obj) { return obj && obj.__esModule ? obj.default : obj; };
-__DEFINE__(1742957056452, function(require, module, exports) {
+__DEFINE__(1744442642933, function(require, module, exports) {
 
 }, function(modId) {var map = {}; return __REQUIRE__(map[modId], modId); })
-return __REQUIRE__(1742957056452);
+return __REQUIRE__(1744442642933);
 })()
 //miniprogram-npm-outsideDeps=[]
 //# sourceMappingURL=index.js.map

File diff suppressed because it is too large
+ 1 - 1
unpackage/dist/build/mp-weixin/miniprogram_npm/tim-wx-sdk/index.js


File diff suppressed because it is too large
+ 1 - 1
unpackage/dist/build/mp-weixin/miniprogram_npm/trtc-wx-sdk/index.js


File diff suppressed because it is too large
+ 1 - 1
unpackage/dist/build/mp-weixin/miniprogram_npm/tsignaling-wx/index.js


File diff suppressed because it is too large
+ 1 - 1
unpackage/dist/build/mp-weixin/miniprogram_npm/tuicall-engine-wx/index.js


+ 1 - 1
unpackage/dist/build/mp-weixin/pages/auth/login.wxml

@@ -1 +1 @@
-<view class="content"><view class="force-login-wrap"><view class="force-login__content y-f"><view class="logo"><view class="logo-img"><image src="https://cos.his.cdwjyyh.com/fs/20240423/1287b2bf7c944538905f5092e8ff7db9.png"></image></view><view class="title">彩虹惠医互联网医院</view></view><view class="login-notice">为了提供更优质的服务,请先登录</view><view class="btns"><button class="author-btn" open-type="getPhoneNumber" bindgetphonenumber="{{a}}">一键授权手机号登录</button><button wx:if="{{b}}" class="author-btn" bindtap="{{c}}">一键授权手机号登录</button></view><button class="close-btn" bindtap="{{d}}">暂不登录</button><view class="tips"><checkbox checked="{{e}}" bindtap="{{f}}"/><view bindtap="{{g}}">您同意并接受</view><view class="btn" bindtap="{{h}}">《用户协议》</view><view class="btn" bindtap="{{i}}">《隐私保护》</view></view></view></view><u-popup wx:if="{{n}}" u-s="{{['d']}}" bindclose="{{l}}" bindopen="{{m}}" u-i="1e427071-0" bind:__l="__l" u-p="{{n}}"><view class="wxAuth"><view class="title">编辑头像和昵称</view><weixin-auth class="wx-box r" bindupdateUser="{{k}}" u-r="wxauth" u-i="1e427071-1,1e427071-0" bind:__l="__l"></weixin-auth></view></u-popup></view>
+<view class="content"><view class="force-login-wrap"><view class="force-login__content y-f"><view class="logo"><view class="logo-img"><image src="https://cos.his.cdwjyyh.com/fs/20240423/1287b2bf7c944538905f5092e8ff7db9.png"></image></view><view class="title">御君方互联网医院</view></view><view class="login-notice">为了提供更优质的服务,请先登录</view><view class="btns"><button class="author-btn" open-type="getPhoneNumber" bindgetphonenumber="{{a}}">一键授权手机号登录</button><button wx:if="{{b}}" class="author-btn" bindtap="{{c}}">一键授权手机号登录</button></view><button class="close-btn" bindtap="{{d}}">暂不登录</button><view class="tips"><checkbox checked="{{e}}" bindtap="{{f}}"/><view bindtap="{{g}}">您同意并接受</view><view class="btn" bindtap="{{h}}">《用户协议》</view><view class="btn" bindtap="{{i}}">《隐私保护》</view></view></view></view><u-popup wx:if="{{n}}" u-s="{{['d']}}" bindclose="{{l}}" bindopen="{{m}}" u-i="1e427071-0" bind:__l="__l" u-p="{{n}}"><view class="wxAuth"><view class="title">编辑头像和昵称</view><weixin-auth class="wx-box r" bindupdateUser="{{k}}" u-r="wxauth" u-i="1e427071-1,1e427071-0" bind:__l="__l"></weixin-auth></view></u-popup></view>

File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/pages/index/index.js


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/pages/index/index.wxml


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/pages/index/index.wxss


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/pages_company/index.js


+ 1 - 1
unpackage/dist/build/mp-weixin/pages_company/index.wxml

@@ -1 +1 @@
-<view class="top-cont"><view class="content"><view class="user-info"><view class="left"><view class="name-phone"><view wx:if="{{a}}" class="name">{{b}}</view><view wx:if="{{c}}" class="phone">{{d}}</view></view></view><view wx:if="{{e}}" class="msg-box">{{f}}</view></view><view class="used-tools"><view class="title">常用工具</view><view class="tools-list"><view class="item" bindtap="{{g}}"><image src="/static/images/icon_my_coupon.png" mode=""></image><text class="text">私域疗法券</text></view><view class="item" bindtap="{{h}}"><image src="/static/images/icon_my_coupon.png" mode=""></image><text class="text">中药免单券</text></view><view class="item" bindtap="{{i}}"><image src="/static/images/icon_company_2.png" mode=""></image><text class="text">疗法</text></view><view class="item" bindtap="{{j}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">会诊</text></view><view class="item" bindtap="{{k}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">按方开药</text></view><view class="item" bindtap="{{l}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">套餐订单</text></view><view class="item" bindtap="{{m}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">问诊订单</text></view><view class="item" bindtap="{{n}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">药品订单</text></view><view class="item" bindtap="{{o}}"><image src="/static/images/icon_company_3.png" mode=""></image><view class="text">健康档案</view></view></view></view><view class="logout" bindtap="{{p}}">退出登录</view></view></view>
+<view class="top-cont"><view class="content"><view class="user-info"><view class="left"><view class="name-phone"><view wx:if="{{a}}" class="name">{{b}}</view><view wx:if="{{c}}" class="phone">{{d}}</view></view></view><view wx:if="{{e}}" class="msg-box">{{f}}</view></view><view class="used-tools"><view class="title">常用工具</view><view class="tools-list"><view class="item" bindtap="{{g}}"><image src="/static/images/icon_my_coupon.png" mode=""></image><text class="text">私域疗法券</text></view><view class="item" bindtap="{{h}}"><image src="/static/images/icon_my_coupon.png" mode=""></image><text class="text">中药免单券</text></view><view class="item" bindtap="{{i}}"><image src="/static/images/icon_company_2.png" mode=""></image><text class="text">疗法</text></view><view class="item" bindtap="{{j}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">会诊</text></view><view class="item" bindtap="{{k}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">按方开药</text></view><view class="item" bindtap="{{l}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">套餐订单</text></view><view class="item" bindtap="{{m}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">问诊订单</text></view><view class="item" bindtap="{{n}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">药品订单</text></view><view class="item" bindtap="{{o}}"><image src="/static/images/icon_company_3.png" mode=""></image><view class="text">健康档案</view></view><view class="item" bindtap="{{p}}"><image src="/static/images/icon_company_3.png" mode=""></image><text class="text">公司码</text></view></view></view><view class="logout" bindtap="{{q}}">退出登录</view></view></view>

File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/pages_course/video.js


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/pages_course/video.wxml


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/build/mp-weixin/pages_course/video.wxss


+ 1 - 2
unpackage/dist/build/mp-weixin/project.config.json

@@ -11,7 +11,6 @@
     "minified": true,
     "newFeature": true,
     "bigPackageSizeSupport": true,
-    "packNpmRelationList": [],
     "babelSetting": {
       "ignore": [],
       "disablePlugins": [],
@@ -20,7 +19,7 @@
   },
   "compileType": "miniprogram",
   "libVersion": "3.7.10",
-  "appid": "wx73f85f8d62769119",
+  "appid": "wxc3f0a952b7bc2b94",
   "projectname": "his_user_app",
   "condition": {},
   "editorSetting": {

+ 0 - 7
unpackage/dist/dev/mp-weixin/api/adv.js

@@ -1,7 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getAdvList(data) {
-  return request("/app/adv/getAdvList", data, "GET");
-}
-exports.getAdvList = getAdvList;

+ 0 - 15
unpackage/dist/dev/mp-weixin/api/article.js

@@ -1,15 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getArticleList(data) {
-  return request("/app/article/getArticleList", data, "GET");
-}
-function getArticleById(data) {
-  return request("/app/article/getArticleById", data, "GET");
-}
-function getArticleCateList(data) {
-  return request("/app/article/getArticleCateList", data, "GET");
-}
-exports.getArticleById = getArticleById;
-exports.getArticleCateList = getArticleCateList;
-exports.getArticleList = getArticleList;

+ 0 - 27
unpackage/dist/dev/mp-weixin/api/common.js

@@ -1,27 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getCitys(data) {
-  return request("/app/common/getCitys", data, "GET");
-}
-function getTlsSig(data) {
-  return request("/app/common/getTlsSig", data, "GET");
-}
-function getDictByKey(data) {
-  return request("/app/common/getDictByKey", data, "GET");
-}
-function getConfigByKey(data) {
-  return request("/app/common/getConfigByKey", data, "GET");
-}
-function getHospitalList(data) {
-  return request("/app/common/getHospitalList", data, "GET");
-}
-function getDepartmentList(data) {
-  return request("/app/common/getDepartmentList", data, "GET");
-}
-exports.getCitys = getCitys;
-exports.getConfigByKey = getConfigByKey;
-exports.getDepartmentList = getDepartmentList;
-exports.getDictByKey = getDictByKey;
-exports.getHospitalList = getHospitalList;
-exports.getTlsSig = getTlsSig;

+ 0 - 15
unpackage/dist/dev/mp-weixin/api/companyUser.js

@@ -1,15 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function login(data) {
-  return request("/app/companyUser/login", data, "POST", "application/json;charset=UTF-8");
-}
-function getUserInfo(data) {
-  return request("/app/companyUser/getUserInfo", data, "GET", "application/json;charset=UTF-8");
-}
-function bindCompanyUser(data) {
-  return request("/app/companyUser/bindCompanyUser", data, "POST", "application/json;charset=UTF-8");
-}
-exports.bindCompanyUser = bindCompanyUser;
-exports.getUserInfo = getUserInfo;
-exports.login = login;

+ 0 - 19
unpackage/dist/dev/mp-weixin/api/coupon.js

@@ -1,19 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getCouponList(data) {
-  return request("/app/coupon/getCouponList", data, "GET");
-}
-function getCouponById(data) {
-  return request("/app/coupon/getCouponById", data, "GET");
-}
-function genCode(data) {
-  return request("/app/coupon/genCode", data, "GET");
-}
-function receive(data) {
-  return request("/app/coupon/receive", data, "POST", "application/json;charset=UTF-8");
-}
-exports.genCode = genCode;
-exports.getCouponById = getCouponById;
-exports.getCouponList = getCouponList;
-exports.receive = receive;

+ 0 - 47
unpackage/dist/dev/mp-weixin/api/course.js

@@ -1,47 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function loginByMp(data) {
-  return request("/app/wx/courseLogin", data, "POST", "application/json;charset=UTF-8", "https://h5api.his.cdwjyyh.com");
-}
-function getRealLink(data) {
-  return request("/app/course/getRealLink", data, "GET", "", "https://h5api.his.cdwjyyh.com");
-}
-function getH5CourseByVideoId(data) {
-  return request("/app/course/getH5CourseByVideoId", data, "GET", "", "https://h5api.his.cdwjyyh.com");
-}
-function getH5CourseVideoDetails(data) {
-  return request("/app/course/getH5CourseVideoDetails", data, "GET", "", "https://h5api.his.cdwjyyh.com");
-}
-function courseAnswer(data) {
-  return request("/app/course/courseAnswer", data, "POST", "application/json;charset=UTF-8", "https://h5api.his.cdwjyyh.com");
-}
-function getFinishCourseVideo(data) {
-  return request("/app/course/updateWatchDuration", data, "POST", "application/json;charset=UTF-8", "https://h5api.his.cdwjyyh.com");
-}
-function getIsAddKf(data) {
-  return request("/app/course/isAddKf", data, "POST", "application/json;charset=UTF-8", "https://h5api.his.cdwjyyh.com");
-}
-function getInternetTraffic(data) {
-  return request("/app/course/getInternetTraffic", data, "POST", "application/json;charset=UTF-8", "https://h5api.his.cdwjyyh.com");
-}
-function getIntegralByH5Video(data) {
-  return request("/app/course/getIntegralByH5Video", data, "POST", "application/json;charset=UTF-8", "https://h5api.his.cdwjyyh.com");
-}
-function sendReward(data) {
-  return request("/app/course/sendReward", data, "POST", "application/json;charset=UTF-8", "https://h5api.his.cdwjyyh.com");
-}
-function getErrMsg(data) {
-  return request("/app/course/getErrMsg", data, "POST", "application/x-www-form-urlencoded", "https://h5api.his.cdwjyyh.com");
-}
-exports.courseAnswer = courseAnswer;
-exports.getErrMsg = getErrMsg;
-exports.getFinishCourseVideo = getFinishCourseVideo;
-exports.getH5CourseByVideoId = getH5CourseByVideoId;
-exports.getH5CourseVideoDetails = getH5CourseVideoDetails;
-exports.getIntegralByH5Video = getIntegralByH5Video;
-exports.getInternetTraffic = getInternetTraffic;
-exports.getIsAddKf = getIsAddKf;
-exports.getRealLink = getRealLink;
-exports.loginByMp = loginByMp;
-exports.sendReward = sendReward;

+ 0 - 11
unpackage/dist/dev/mp-weixin/api/courseOrder.js

@@ -1,11 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function payment(data) {
-  return request("/app/courseOrder/weChatPayment", data, "POST", "application/json;charset=UTF-8");
-}
-function getCourseOrderById(data) {
-  return request("/app/courseOrder/getCourseOrderById", data, "GET");
-}
-exports.getCourseOrderById = getCourseOrderById;
-exports.payment = payment;

+ 0 - 7
unpackage/dist/dev/mp-weixin/api/department.js

@@ -1,7 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getDepartmentList(data) {
-  return request("/app/department/getDepartmentList", data, "GET");
-}
-exports.getDepartmentList = getDepartmentList;

+ 0 - 11
unpackage/dist/dev/mp-weixin/api/disease.js

@@ -1,11 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getDiseaseList(data) {
-  return request("/app/disease/getDiseaseList", data, "GET");
-}
-function getDiseaseById(data) {
-  return request("/app/disease/getDiseaseById", data, "GET");
-}
-exports.getDiseaseById = getDiseaseById;
-exports.getDiseaseList = getDiseaseList;

+ 0 - 27
unpackage/dist/dev/mp-weixin/api/doctor.js

@@ -1,27 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getMyDoctorList(data) {
-  return request("/app/doctor/getMyDoctorList", data, "GET");
-}
-function getDoctorDetails(data) {
-  return request("/app/doctor/getDoctorDetails", data, "GET");
-}
-function getDoctorPingList(data) {
-  return request("/app/doctor/getDoctorPingList", data, "GET");
-}
-function getDoctorList(data) {
-  return request("/app/doctor/getDoctorList", data, "GET");
-}
-function checkFollow(data) {
-  return request("/app/doctor/checkFollow", data, "GET");
-}
-function doFollow(data) {
-  return request("/app/doctor/doFollow", data, "POST", "application/json;charset=UTF-8");
-}
-exports.checkFollow = checkFollow;
-exports.doFollow = doFollow;
-exports.getDoctorDetails = getDoctorDetails;
-exports.getDoctorList = getDoctorList;
-exports.getDoctorPingList = getDoctorPingList;
-exports.getMyDoctorList = getMyDoctorList;

+ 0 - 15
unpackage/dist/dev/mp-weixin/api/doctorArticle.js

@@ -1,15 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getDoctorArticleCateList(data) {
-  return request("/app/doctorArticle/getDoctorArticleCateList", data, "GET");
-}
-function getDoctorArticleList(data) {
-  return request("/app/doctorArticle/getDoctorArticleList", data, "GET");
-}
-function getDoctorArticleById(data) {
-  return request("/app/doctorArticle/getDoctorArticleById", data, "GET");
-}
-exports.getDoctorArticleById = getDoctorArticleById;
-exports.getDoctorArticleCateList = getDoctorArticleCateList;
-exports.getDoctorArticleList = getDoctorArticleList;

+ 0 - 23
unpackage/dist/dev/mp-weixin/api/drugReport.js

@@ -1,23 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getUserFollowDoctor() {
-  return request("/app/drugReport/getUserFollowDoctor", null, "GET");
-}
-function getDrugReportList(data) {
-  return request("/app/drugReport/getDrugReportList", data, "GET");
-}
-function getDrugReportById(data) {
-  return request("/app/drugReport/getDrugReportById", data, "GET");
-}
-function pingReport(data) {
-  return request("/app/drugReport/pingReport", data, "POST", "application/json;charset=UTF-8");
-}
-function startDrugReport(data) {
-  return request("/app/drugReport/startDrugReport", data, "POST", "application/json;charset=UTF-8");
-}
-exports.getDrugReportById = getDrugReportById;
-exports.getDrugReportList = getDrugReportList;
-exports.getUserFollowDoctor = getUserFollowDoctor;
-exports.pingReport = pingReport;
-exports.startDrugReport = startDrugReport;

+ 0 - 15
unpackage/dist/dev/mp-weixin/api/follow.js

@@ -1,15 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getFollowList(data) {
-  return request("/app/follow/getFollowList", data, "GET");
-}
-function getFollowById(data) {
-  return request("/app/follow/getFollowById", data, "GET");
-}
-function doFollow(data) {
-  return request("/app/follow/doFollow", data, "POST", "application/json;charset=UTF-8");
-}
-exports.doFollow = doFollow;
-exports.getFollowById = getFollowById;
-exports.getFollowList = getFollowList;

+ 0 - 31
unpackage/dist/dev/mp-weixin/api/healthRecords.js

@@ -1,31 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function myRecord() {
-  return request("/app/healthRecord/myRecord", null, "GET");
-}
-function HealthLife(data) {
-  return request("/app/healthRecord/HealthLife", data, "GET");
-}
-function healthHistoryTempList() {
-  return request("/app/healthRecord/healthHistoryTempList", null, "GET");
-}
-function HealthDataList(data) {
-  return request("/app/healthRecord/HealthDataList", data, "GET");
-}
-function editRecord(data) {
-  return request("/app/healthRecord/editRecord", data, "PUT", "application/json;charset=UTF-8");
-}
-function addRecord(data) {
-  return request("/app/healthRecord/addRecord", data, "POST", "application/json;charset=UTF-8");
-}
-function addFsHealthLife(data) {
-  return request("/app/healthRecord/addFsHealthLife", data, "POST", "application/json;charset=UTF-8");
-}
-exports.HealthDataList = HealthDataList;
-exports.HealthLife = HealthLife;
-exports.addFsHealthLife = addFsHealthLife;
-exports.addRecord = addRecord;
-exports.editRecord = editRecord;
-exports.healthHistoryTempList = healthHistoryTempList;
-exports.myRecord = myRecord;

+ 0 - 19
unpackage/dist/dev/mp-weixin/api/healthTongue.js

@@ -1,19 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getHealthTongueList(data) {
-  return request("/app/healthTongue/getHealthTongueList", data, "GET");
-}
-function getCount(data) {
-  return request("/app/healthTongue/getCount", data, "GET");
-}
-function getHealthTongueById(id) {
-  return request("/app/healthTongue/getHealthTongueById/" + id, null, "GET");
-}
-function add(data) {
-  return request("/app/healthTongue/add", data, "POST", "application/json;charset=UTF-8");
-}
-exports.add = add;
-exports.getCount = getCount;
-exports.getHealthTongueById = getHealthTongueById;
-exports.getHealthTongueList = getHealthTongueList;

+ 0 - 11
unpackage/dist/dev/mp-weixin/api/hospital.js

@@ -1,11 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getHospitalList(data) {
-  return request("/app/hospital/getHospitalList", data, "GET");
-}
-function getHospitalById(data) {
-  return request("/app/hospital/getHospitalById", data, "GET");
-}
-exports.getHospitalById = getHospitalById;
-exports.getHospitalList = getHospitalList;

+ 0 - 43
unpackage/dist/dev/mp-weixin/api/index.js

@@ -1,43 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getFamousPrescribeList(data) {
-  return request("/app/index/getFamousPrescribeList", data, "GET");
-}
-function getFamousPrescribeById(data) {
-  return request("/app/index/getFamousPrescribeById", data, "GET");
-}
-function getQuestionsList(data) {
-  return request("/app/index/getQuestionsList", data, "GET");
-}
-function getQuestionsById(data) {
-  return request("/app/index/getQuestionsById", data, "GET");
-}
-function getMedicatedFoodList(data) {
-  return request("/app/index/getMedicatedFoodList", data, "GET");
-}
-function getMedicatedFoodById(data) {
-  return request("/app/index/getMedicatedFoodById", data, "GET");
-}
-function getVesselList(data) {
-  return request("/app/index/getVesselList", data, "GET");
-}
-function getVesselById(data) {
-  return request("/app/index/getVesselById", data, "GET");
-}
-function getChineseMedicineList(data) {
-  return request("/app/index/getChineseMedicineList", data, "GET");
-}
-function getChineseMedicineById(data) {
-  return request("/app/index/getChineseMedicineById", data, "GET");
-}
-exports.getChineseMedicineById = getChineseMedicineById;
-exports.getChineseMedicineList = getChineseMedicineList;
-exports.getFamousPrescribeById = getFamousPrescribeById;
-exports.getFamousPrescribeList = getFamousPrescribeList;
-exports.getMedicatedFoodById = getMedicatedFoodById;
-exports.getMedicatedFoodList = getMedicatedFoodList;
-exports.getQuestionsById = getQuestionsById;
-exports.getQuestionsList = getQuestionsList;
-exports.getVesselById = getVesselById;
-exports.getVesselList = getVesselList;

+ 0 - 63
unpackage/dist/dev/mp-weixin/api/inquiryOrder.js

@@ -1,63 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function confirm(data) {
-  return request("/app/inquiryOrder/confirm", data, "POST", "application/json;charset=UTF-8");
-}
-function create(data) {
-  return request("/app/inquiryOrder/create", data, "POST", "application/json;charset=UTF-8");
-}
-function pay(data) {
-  return request("/app/inquiryOrder/pay", data, "POST", "application/json;charset=UTF-8");
-}
-function compute(data) {
-  return request("/app/inquiryOrder/compute", data, "POST", "application/json;charset=UTF-8");
-}
-function payment(data) {
-  return request("/app/inquiryOrder/payment", data, "POST", "application/json;charset=UTF-8");
-}
-function cancel(data) {
-  return request("/app/inquiryOrder/cancel", data, "POST", "application/json;charset=UTF-8");
-}
-function getMyInquiryOrderList(data) {
-  return request("/app/inquiryOrder/getMyInquiryOrderList", data, "GET");
-}
-function getMyInquiryOrderById(data) {
-  return request("/app/inquiryOrder/getMyInquiryOrderById", data, "GET");
-}
-function getMyInquiryOrderPingList(data) {
-  return request("/app/inquiryOrder/getMyInquiryOrderPingList", data, "GET");
-}
-function getInquiryOrderById(data) {
-  return request("/app/inquiryOrder/getInquiryOrderById", data, "GET");
-}
-function getCompanyUserInquiryOrderById(data) {
-  return request("/app/inquiryOrder/getCompanyUserInquiryOrderById", data, "GET");
-}
-function pingOrder(data) {
-  return request("/app/inquiryOrder/pingOrder", data, "POST", "application/json;charset=UTF-8");
-}
-function getInquiryTemp(data) {
-  return request("/app/inquiryOrder/getInquiryTemp", data, "GET");
-}
-function getInquiryOrderReport(data) {
-  return request("/app/inquiryOrder/getInquiryOrderReport", data, "GET");
-}
-function getCompanyUserInquiryOrderList(data) {
-  return request("/app/inquiryOrder/getCompanyUserInquiryOrderList", data, "GET");
-}
-exports.cancel = cancel;
-exports.compute = compute;
-exports.confirm = confirm;
-exports.create = create;
-exports.getCompanyUserInquiryOrderById = getCompanyUserInquiryOrderById;
-exports.getCompanyUserInquiryOrderList = getCompanyUserInquiryOrderList;
-exports.getInquiryOrderById = getInquiryOrderById;
-exports.getInquiryOrderReport = getInquiryOrderReport;
-exports.getInquiryTemp = getInquiryTemp;
-exports.getMyInquiryOrderById = getMyInquiryOrderById;
-exports.getMyInquiryOrderList = getMyInquiryOrderList;
-exports.getMyInquiryOrderPingList = getMyInquiryOrderPingList;
-exports.pay = pay;
-exports.payment = payment;
-exports.pingOrder = pingOrder;

+ 0 - 35
unpackage/dist/dev/mp-weixin/api/integral.js

@@ -1,35 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getIntegralGoodsList(data) {
-  return request("/app/integral/getIntegralGoodsList", data, "GET");
-}
-function getIntegralGoodsById(data) {
-  return request("/app/integral/getIntegralGoodsById", data, "GET");
-}
-function getUserIntegralLogsList(data) {
-  return request("/app/integral/getUserIntegralLogsList", data, "GET");
-}
-function getIntegralOrderList(data) {
-  return request("/app/integral/getIntegralOrderList", data, "GET");
-}
-function getIntegralOrderById(data) {
-  return request("/app/integral/getIntegralOrderById", data, "GET");
-}
-function createOrder(data) {
-  return request("/app/integral/createOrder", data, "POST", "application/json;charset=UTF-8");
-}
-function getUserSign() {
-  return request("/app/integral/getUserSign", null, "GET");
-}
-function doSign(data) {
-  return request("/app/integral/sign", data, "POST", "application/json;charset=UTF-8");
-}
-exports.createOrder = createOrder;
-exports.doSign = doSign;
-exports.getIntegralGoodsById = getIntegralGoodsById;
-exports.getIntegralGoodsList = getIntegralGoodsList;
-exports.getIntegralOrderById = getIntegralOrderById;
-exports.getIntegralOrderList = getIntegralOrderList;
-exports.getUserIntegralLogsList = getUserIntegralLogsList;
-exports.getUserSign = getUserSign;

+ 0 - 19
unpackage/dist/dev/mp-weixin/api/package.js

@@ -1,19 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getPackagCateList(data) {
-  return request("/app/package/getPackagCateList", data, "GET");
-}
-function getPackageList(data) {
-  return request("/app/package/getPackageList", data, "GET");
-}
-function getPackageById(data) {
-  return request("/app/package/getPackageById", data, "GET");
-}
-function getPackageDoctorList(data) {
-  return request("/app/package/getPackageDoctorList", data, "GET");
-}
-exports.getPackagCateList = getPackagCateList;
-exports.getPackageById = getPackageById;
-exports.getPackageDoctorList = getPackageDoctorList;
-exports.getPackageList = getPackageList;

+ 0 - 47
unpackage/dist/dev/mp-weixin/api/packageOrder.js

@@ -1,47 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function create(data) {
-  return request("/app/packageOrder/create", data, "POST", "application/json;charset=UTF-8");
-}
-function compute(data) {
-  return request("/app/packageOrder/compute", data, "POST", "application/json;charset=UTF-8");
-}
-function pay(data) {
-  return request("/app/packageOrder/pay", data, "POST", "application/json;charset=UTF-8");
-}
-function payment(data) {
-  return request("/app/packageOrder/payment", data, "POST", "application/json;charset=UTF-8");
-}
-function getPackageOrderById(data) {
-  return request("/app/packageOrder/getPackageOrderById", data, "GET");
-}
-function getMyPackageOrderList(data) {
-  return request("/app/packageOrder/getMyPackageOrderList", data, "GET");
-}
-function getCompanyUserPackageOrderList(data) {
-  return request("/app/packageOrder/getCompanyUserPackageOrderList", data, "GET");
-}
-function getSharePackageOrderById(data) {
-  return request("/app/packageOrder/getSharePackageOrderById", data, "GET");
-}
-function getCompanyUserPackageOrderById(data) {
-  return request("/app/packageOrder/getCompanyUserPackageOrderById", data, "GET");
-}
-function cancelOrder(data) {
-  return request("/app/packageOrder/cancel", data, "POST", "application/json;charset=UTF-8");
-}
-function getOrderCount(data) {
-  return request("/app/packageOrder/getOrderCount", data, "GET");
-}
-exports.cancelOrder = cancelOrder;
-exports.compute = compute;
-exports.create = create;
-exports.getCompanyUserPackageOrderById = getCompanyUserPackageOrderById;
-exports.getCompanyUserPackageOrderList = getCompanyUserPackageOrderList;
-exports.getMyPackageOrderList = getMyPackageOrderList;
-exports.getOrderCount = getOrderCount;
-exports.getPackageOrderById = getPackageOrderById;
-exports.getSharePackageOrderById = getSharePackageOrderById;
-exports.pay = pay;
-exports.payment = payment;

+ 0 - 23
unpackage/dist/dev/mp-weixin/api/patient.js

@@ -1,23 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getPatientList() {
-  return request("/app/patient/getPatientList", null, "GET");
-}
-function getPatientById(data) {
-  return request("/app/patient/getPatientById", data, "GET");
-}
-function delPatient(data) {
-  return request("/app/patient/delPatient", data, "POST", "application/json;charset=UTF-8");
-}
-function addPatient(data) {
-  return request("/app/patient/addPatient", data, "POST", "application/json;charset=UTF-8");
-}
-function editPatient(data) {
-  return request("/app/patient/editPatient", data, "POST", "application/json;charset=UTF-8");
-}
-exports.addPatient = addPatient;
-exports.delPatient = delPatient;
-exports.editPatient = editPatient;
-exports.getPatientById = getPatientById;
-exports.getPatientList = getPatientList;

+ 0 - 11
unpackage/dist/dev/mp-weixin/api/prescribe.js

@@ -1,11 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getPrescribeList(data) {
-  return request("/app/prescribe/getPrescribeList", data, "GET");
-}
-function getPrescribeById(data) {
-  return request("/app/prescribe/getPrescribeById", data, "GET");
-}
-exports.getPrescribeById = getPrescribeById;
-exports.getPrescribeList = getPrescribeList;

+ 0 - 27
unpackage/dist/dev/mp-weixin/api/storeAfterSales.js

@@ -1,27 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getStoreOrderItems(data) {
-  return request("/app/storeAfterSales/getStoreOrderItems", data, "GET");
-}
-function applyAfterSales(data) {
-  return request("/app/storeAfterSales/applyAfterSales", data, "POST", "application/json;charset=UTF-8");
-}
-function getStoreAfterSalesList(data) {
-  return request("/app/storeAfterSales/getStoreAfterSalesList", data, "GET");
-}
-function getStoreAfterSalesById(data) {
-  return request("/app/storeAfterSales/getStoreAfterSalesById", data, "GET");
-}
-function revoke(data) {
-  return request("/app/storeAfterSales/revoke", data, "POST", "application/json;charset=UTF-8");
-}
-function addDelivery(data) {
-  return request("/app/storeAfterSales/addDelivery", data, "POST", "application/json;charset=UTF-8");
-}
-exports.addDelivery = addDelivery;
-exports.applyAfterSales = applyAfterSales;
-exports.getStoreAfterSalesById = getStoreAfterSalesById;
-exports.getStoreAfterSalesList = getStoreAfterSalesList;
-exports.getStoreOrderItems = getStoreOrderItems;
-exports.revoke = revoke;

+ 0 - 47
unpackage/dist/dev/mp-weixin/api/storeOrder.js

@@ -1,47 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getMyStoreOrderList(data) {
-  return request("/app/storeOrder/getMyStoreOrderList", data, "GET");
-}
-function getCompanyUserStoreOrderList(data) {
-  return request("/app/storeOrder/getCompanyUserStoreOrderList", data, "GET");
-}
-function getMyStoreOrderById(data) {
-  return request("/app/storeOrder/getMyStoreOrderById", data, "GET");
-}
-function getStoreOrderById(data) {
-  return request("/app/storeOrder/getStoreOrderById", data, "GET");
-}
-function getCompanyUserStoreOrderById(data) {
-  return request("/app/storeOrder/getCompanyUserStoreOrderById", data, "GET");
-}
-function pay(data) {
-  return request("/app/storeOrder/pay", data, "POST", "application/json;charset=UTF-8");
-}
-function payment(data) {
-  return request("/app/storeOrder/payment", data, "POST", "application/json;charset=UTF-8");
-}
-function compute(data) {
-  return request("/app/storeOrder/compute", data, "POST", "application/json;charset=UTF-8");
-}
-function cancelOrder(data) {
-  return request("/app/storeOrder/cancelOrder", data, "POST", "application/json;charset=UTF-8");
-}
-function finishOrder(data) {
-  return request("/app/storeOrder/finishOrder", data, "POST", "application/json;charset=UTF-8");
-}
-function getExpress(data) {
-  return request("/app/storeOrder/getExpress", data, "POST", "application/json;charset=UTF-8");
-}
-exports.cancelOrder = cancelOrder;
-exports.compute = compute;
-exports.finishOrder = finishOrder;
-exports.getCompanyUserStoreOrderById = getCompanyUserStoreOrderById;
-exports.getCompanyUserStoreOrderList = getCompanyUserStoreOrderList;
-exports.getExpress = getExpress;
-exports.getMyStoreOrderById = getMyStoreOrderById;
-exports.getMyStoreOrderList = getMyStoreOrderList;
-exports.getStoreOrderById = getStoreOrderById;
-exports.pay = pay;
-exports.payment = payment;

+ 0 - 27
unpackage/dist/dev/mp-weixin/api/test.js

@@ -1,27 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getTestList(data) {
-  return request("/app/test/getTestList", data, "GET");
-}
-function getTestDetails(data) {
-  return request("/app/test/getTestDetails", data, "GET");
-}
-function getTestTempDetails(data) {
-  return request("/app/test/getTestTempDetails", data, "GET");
-}
-function getTestReport(data) {
-  return request("/app/test/getTestReport", data, "GET");
-}
-function getTestReportImg(data) {
-  return request("/app/test/getTestReportImg", data, "GET");
-}
-function doReport(data) {
-  return request("/app/test/doReport", data, "POST", "application/json;charset=UTF-8");
-}
-exports.doReport = doReport;
-exports.getTestDetails = getTestDetails;
-exports.getTestList = getTestList;
-exports.getTestReport = getTestReport;
-exports.getTestReportImg = getTestReportImg;
-exports.getTestTempDetails = getTestTempDetails;

+ 0 - 35
unpackage/dist/dev/mp-weixin/api/user.js

@@ -1,35 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function wxLogin(data) {
-  return request("/app/wx/login", data, "POST", "application/json;charset=UTF-8");
-}
-function getUserInfo() {
-  return request("/app/user/getUserInfo", null, "GET");
-}
-function checkLogin() {
-  return request("/app/user/checkLogin", null, "GET");
-}
-function editUser(data) {
-  return request("/app/user/editUser", data, "POST", "application/json;charset=UTF-8");
-}
-function registerDoctor(data) {
-  return request("/app/user/registerDoctor", data, "POST", "application/json;charset=UTF-8");
-}
-function getMyCouponList(data) {
-  return request("/app/user/getMyCouponList", data, "GET");
-}
-function getMyEnableCouponList(data) {
-  return request("/app/user/getMyEnableCouponList", data, "GET");
-}
-function getAppContactWay(userId) {
-  return request("/app/user/getAppContactWay/" + userId, null, "GET");
-}
-exports.checkLogin = checkLogin;
-exports.editUser = editUser;
-exports.getAppContactWay = getAppContactWay;
-exports.getMyCouponList = getMyCouponList;
-exports.getMyEnableCouponList = getMyEnableCouponList;
-exports.getUserInfo = getUserInfo;
-exports.registerDoctor = registerDoctor;
-exports.wxLogin = wxLogin;

+ 0 - 31
unpackage/dist/dev/mp-weixin/api/userAddress.js

@@ -1,31 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function getAddressByDefault() {
-  return request("/app/userAddress/getAddressByDefault", null, "GET");
-}
-function getAddressList() {
-  return request("/app/userAddress/getAddressList", null, "GET");
-}
-function getAddressById(data) {
-  return request("/app/userAddress/getAddressById", data, "GET");
-}
-function delAddress(data) {
-  return request("/app/userAddress/delAddress", data, "POST", "application/json;charset=UTF-8");
-}
-function addAddress(data) {
-  return request("/app/userAddress/addAddress", data, "POST", "application/json;charset=UTF-8");
-}
-function editAddress(data) {
-  return request("/app/userAddress/editAddress", data, "POST", "application/json;charset=UTF-8");
-}
-function parseAddress(data) {
-  return request("/app/userAddress/parseAddress", data, "POST", "application/json;charset=UTF-8");
-}
-exports.addAddress = addAddress;
-exports.delAddress = delAddress;
-exports.editAddress = editAddress;
-exports.getAddressByDefault = getAddressByDefault;
-exports.getAddressById = getAddressById;
-exports.getAddressList = getAddressList;
-exports.parseAddress = parseAddress;

+ 0 - 11
unpackage/dist/dev/mp-weixin/api/userVipOrder.js

@@ -1,11 +0,0 @@
-"use strict";
-var common_request = require("../common/request.js");
-let request = new common_request.Request().http;
-function payment(data) {
-  return request("/app/userVip/weChatPayment", data, "POST", "application/json;charset=UTF-8");
-}
-function getVipOrderById(data) {
-  return request("/app/userVip/getVipOrderById", data, "GET");
-}
-exports.getVipOrderById = getVipOrderById;
-exports.payment = payment;

File diff suppressed because it is too large
+ 0 - 282
unpackage/dist/dev/mp-weixin/app.js


+ 0 - 206
unpackage/dist/dev/mp-weixin/app.json

@@ -1,206 +0,0 @@
-{
-  "pages": [
-    "pages/common/launch",
-    "pages/auth/login",
-    "pages/index/index",
-    "pages/index/h5",
-    "pages/index/content",
-    "pages/doctor/index",
-    "pages/store/index",
-    "pages/user/index",
-    "pages/TUIKit/TUIPages/TUIConversation/index",
-    "pages/TUIKit/TUIPages/TUIConversation/create",
-    "pages/TUIKit/TUIPages/TUIChat/index",
-    "pages/TUIKit/TUIPages/TUIChat/components/message-elements/video-play"
-  ],
-  "subPackages": [
-    {
-      "root": "pages_index",
-      "pages": [
-        "testList",
-        "testDetails",
-        "test",
-        "testResult",
-        "testResultImg",
-        "articleList",
-        "articleDetails",
-        "diseaseList",
-        "diseaseDetails",
-        "hospitalList",
-        "hospitalDetails",
-        "search",
-        "famousPrescribeList",
-        "famousPrescribeDetails",
-        "vesselList",
-        "vesselDetails",
-        "chineseMedicineList",
-        "chineseMedicineDetails",
-        "medicatedFoodList",
-        "medicatedFoodDetails",
-        "questionsList",
-        "questionsDetails",
-        "packageList",
-        "packageDetails",
-        "packageForm"
-      ]
-    },
-    {
-      "root": "pages_doctor",
-      "pages": [
-        "doctorArticleList",
-        "doctorArticleDetails",
-        "doctorList",
-        "doctorDetails",
-        "doctorPingList",
-        "doctorInfo",
-        "doctorImgs"
-      ]
-    },
-    {
-      "root": "pages_order",
-      "pages": [
-        "inquiryOrderList",
-        "inquiryOrderDetails",
-        "inquiryOrderPingList",
-        "inquirySelect",
-        "inquirySelectType",
-        "inquiryForm1",
-        "inquiryForm2_1",
-        "inquiryForm2_2",
-        "inquiryForm3",
-        "inquiryPay",
-        "inquiryPayment",
-        "tzPay",
-        "tzWeixinPay",
-        "inquiryOrderPaySuccess",
-        "storeOrderPaySuccess",
-        "courseOrderPayment",
-        "courseOrderPaySuccess",
-        "userVipOrderPayment",
-        "userVipOrderOrderPaySuccess",
-        "pingOrder",
-        "prescribeList",
-        "prescribeDetails",
-        "storeOrderList",
-        "storeOrderDetail",
-        "storeOrderPay",
-        "storeOrderPayment",
-        "inquiryOrderReport",
-        "packageOrderDetails",
-        "packageOrderList",
-        "packageOrderPay",
-        "packageOrderPaySuccess",
-        "storeOrderDelivery",
-        "storeOrderRefundApply",
-        "storeOrderRefundSubmit",
-        "storeOrderRefundList",
-        "storeOrderRefundDetails",
-        "storeOrderRefundAddDelivery",
-        "packageOtherPayment",
-        "packagePayment"
-      ]
-    },
-    {
-      "root": "pages_user",
-      "pages": [
-        "registerDoctor",
-        "about",
-        "address",
-        "addEditAddress",
-        "personInfo",
-        "agreement",
-        "myDoctorList",
-        "patient",
-        "addEditPatient",
-        "myCouponList",
-        "cert",
-        "followList",
-        "followDetails",
-        "drugReportList",
-        "drugReportPing",
-        "drugReportDetails",
-        "doFollow",
-        "integralGoodsList",
-        "integralGoodsDetails",
-        "integralOrderList",
-        "integralOrderDetails",
-        "integralLogsList",
-        "integralOrderPay",
-        "integralOrderPaySuccess",
-        "integral",
-        "price",
-        "healthRecords/index",
-        "healthRecords/add",
-        "healthRecords/edit",
-        "tongue/index",
-        "tongue/report",
-        "tongue/photoPreview",
-        "tongue/tongueList",
-        "addHealthButler"
-      ]
-    },
-    {
-      "root": "pages_company",
-      "pages": [
-        "login",
-        "index",
-        "packageList",
-        "packageDetails",
-        "packageOrderList",
-        "packageOrderDetails",
-        "couponList",
-        "couponDetails",
-        "inquiryOrderList",
-        "inquiryOrderDetails",
-        "storeOrderList",
-        "storeOrderDetail",
-        "storeOrderDelivery"
-      ]
-    },
-    {
-      "root": "pages_course",
-      "pages": [
-        "video"
-      ]
-    }
-  ],
-  "window": {
-    "navigationBarTextStyle": "white",
-    "navigationBarTitleText": "御君方互联网医院",
-    "navigationBarBackgroundColor": "#C39A58",
-    "backgroundColor": "#ffffff"
-  },
-  "tabBar": {
-    "color": "#7e7e7e",
-    "selectedColor": "#C39A58",
-    "borderStyle": "white",
-    "backgroundColor": "#ffffff",
-    "list": [
-      {
-        "pagePath": "pages/index/index",
-        "iconPath": "/static/images/home.png",
-        "selectedIconPath": "/static/images/home_select.png",
-        "text": "首页"
-      },
-      {
-        "pagePath": "pages/TUIKit/TUIPages/TUIConversation/index",
-        "iconPath": "/static/images/inquiry.png",
-        "selectedIconPath": "/static/images/inquiry_select.png",
-        "text": "问诊"
-      },
-      {
-        "pagePath": "pages/store/index",
-        "iconPath": "/static/images/store.png",
-        "selectedIconPath": "/static/images/store_select.png",
-        "text": "疗法"
-      },
-      {
-        "pagePath": "pages/user/index",
-        "iconPath": "/static/images/my.png",
-        "selectedIconPath": "/static/images/my_select.png",
-        "text": "我的"
-      }
-    ]
-  },
-  "usingComponents": {}
-}

File diff suppressed because it is too large
+ 0 - 501
unpackage/dist/dev/mp-weixin/app.wxss


+ 0 - 35
unpackage/dist/dev/mp-weixin/common/assets.js

@@ -1,35 +0,0 @@
-"use strict";
-var _imports_0$6 = "/pages/TUIKit/assets/icon/singlePerson.svg";
-var _imports_1$2 = "/pages/TUIKit/assets/icon/multiPerson.svg";
-var _imports_0$5 = "/pages/TUIKit/assets/icon/selected.svg";
-var _imports_0$4 = "/pages/TUIKit/assets/icon/mute.svg";
-var _imports_0$3 = "/pages/TUIKit/assets/icon/revoked.svg";
-var _imports_1$1 = "/pages/TUIKit/assets/icon/delete.svg";
-var _imports_2$1 = "/pages/TUIKit/assets/icon/forword.svg";
-var _imports_0$2 = "/pages/TUIKit/assets/icon/play_normal@2x.png";
-var _imports_0$1 = "/pages/TUIKit/assets/icon/audio-play.svg";
-var _imports_0 = "/pages/TUIKit/assets/icon/audio.svg";
-var _imports_1 = "/pages/TUIKit/assets/icon/emoji.svg";
-var _imports_2 = "/pages/TUIKit/assets/icon/more.svg";
-var _imports_3 = "/pages/TUIKit/assets/icon/take-photo.svg";
-var _imports_4 = "/pages/TUIKit/assets/icon/send-img.svg";
-var _imports_5 = "/pages/TUIKit/assets/icon/take-video.svg";
-var _imports_6 = "/pages/TUIKit/assets/icon/audio-calling.svg";
-var _imports_7 = "/pages/TUIKit/assets/icon/inquiry.svg";
-exports._imports_0 = _imports_0$6;
-exports._imports_0$1 = _imports_0$5;
-exports._imports_0$2 = _imports_0$4;
-exports._imports_0$3 = _imports_0$3;
-exports._imports_0$4 = _imports_0$2;
-exports._imports_0$5 = _imports_0$1;
-exports._imports_0$6 = _imports_0;
-exports._imports_1 = _imports_1$2;
-exports._imports_1$1 = _imports_1$1;
-exports._imports_1$2 = _imports_1;
-exports._imports_2 = _imports_2$1;
-exports._imports_2$1 = _imports_2;
-exports._imports_3 = _imports_3;
-exports._imports_4 = _imports_4;
-exports._imports_5 = _imports_5;
-exports._imports_6 = _imports_6;
-exports._imports_7 = _imports_7;

+ 0 - 63
unpackage/dist/dev/mp-weixin/common/request.js

@@ -1,63 +0,0 @@
-"use strict";
-var common_vendor = require("./vendor.js");
-class Request {
-  http(router, data = {}, method, contentType, url) {
-    var path = common_vendor.index.getStorageSync("requestPath");
-    let token = "";
-    if (url != null) {
-      path = url;
-      token = common_vendor.index.getStorageSync("AppTokenmini_RTCourse");
-    } else {
-      common_vendor.index.setStorageSync("requestPath", path);
-      token = common_vendor.index.getStorageSync("AppToken");
-    }
-    return new Promise((resolve, reject) => {
-      let CompanyUserToken = common_vendor.index.getStorageSync("CompanyUserToken");
-      var httpContentType = "application/x-www-form-urlencoded";
-      if (contentType != void 0) {
-        httpContentType = contentType;
-      }
-      common_vendor.index.request({
-        header: {
-          "Content-Type": httpContentType,
-          "AppToken": token,
-          "CompanyUserToken": CompanyUserToken
-        },
-        url: `${path}${router}`,
-        data,
-        method,
-        success: (res) => {
-          if (res.data.code == 401) {
-            let pages = getCurrentPages();
-            let url2 = pages[pages.length - 1];
-            console.log(url2);
-            if (url2 != void 0 && url2.route == "pages/auth/login") {
-              resolve(res.data);
-              return;
-            }
-            common_vendor.index.navigateTo({
-              url: "/pages/auth/login",
-              success: () => {
-              },
-              fail: () => {
-              }
-            });
-            return;
-          }
-          if (res.data.token) {
-            common_vendor.index.setStorageSync("AppToken", res.data.token);
-          }
-          resolve(res.data);
-        },
-        fail: (res) => {
-        },
-        complete: (res) => {
-          if (res.data.code == 401) {
-            return false;
-          }
-        }
-      });
-    });
-  }
-}
-exports.Request = Request;

+ 0 - 7213
unpackage/dist/dev/mp-weixin/common/vendor.js

@@ -1,7213 +0,0 @@
-"use strict";
-var _export_sfc = (sfc, props) => {
-  const target = sfc.__vccOpts || sfc;
-  for (const [key, val] of props) {
-    target[key] = val;
-  }
-  return target;
-};
-function makeMap(str, expectsLowerCase) {
-  const map = /* @__PURE__ */ Object.create(null);
-  const list = str.split(",");
-  for (let i = 0; i < list.length; i++) {
-    map[list[i]] = true;
-  }
-  return expectsLowerCase ? (val) => !!map[val.toLowerCase()] : (val) => !!map[val];
-}
-function normalizeStyle(value) {
-  if (isArray(value)) {
-    const res = {};
-    for (let i = 0; i < value.length; i++) {
-      const item = value[i];
-      const normalized = isString(item) ? parseStringStyle(item) : normalizeStyle(item);
-      if (normalized) {
-        for (const key in normalized) {
-          res[key] = normalized[key];
-        }
-      }
-    }
-    return res;
-  } else if (isString(value)) {
-    return value;
-  } else if (isObject$1(value)) {
-    return value;
-  }
-}
-const listDelimiterRE = /;(?![^(]*\))/g;
-const propertyDelimiterRE = /:(.+)/;
-function parseStringStyle(cssText) {
-  const ret = {};
-  cssText.split(listDelimiterRE).forEach((item) => {
-    if (item) {
-      const tmp = item.split(propertyDelimiterRE);
-      tmp.length > 1 && (ret[tmp[0].trim()] = tmp[1].trim());
-    }
-  });
-  return ret;
-}
-function normalizeClass(value) {
-  let res = "";
-  if (isString(value)) {
-    res = value;
-  } else if (isArray(value)) {
-    for (let i = 0; i < value.length; i++) {
-      const normalized = normalizeClass(value[i]);
-      if (normalized) {
-        res += normalized + " ";
-      }
-    }
-  } else if (isObject$1(value)) {
-    for (const name in value) {
-      if (value[name]) {
-        res += name + " ";
-      }
-    }
-  }
-  return res.trim();
-}
-const toDisplayString = (val) => {
-  return isString(val) ? val : val == null ? "" : isArray(val) || isObject$1(val) && (val.toString === objectToString || !isFunction(val.toString)) ? JSON.stringify(val, replacer, 2) : String(val);
-};
-const replacer = (_key, val) => {
-  if (val && val.__v_isRef) {
-    return replacer(_key, val.value);
-  } else if (isMap(val)) {
-    return {
-      [`Map(${val.size})`]: [...val.entries()].reduce((entries, [key, val2]) => {
-        entries[`${key} =>`] = val2;
-        return entries;
-      }, {})
-    };
-  } else if (isSet(val)) {
-    return {
-      [`Set(${val.size})`]: [...val.values()]
-    };
-  } else if (isObject$1(val) && !isArray(val) && !isPlainObject(val)) {
-    return String(val);
-  }
-  return val;
-};
-const EMPTY_OBJ = Object.freeze({});
-const EMPTY_ARR = Object.freeze([]);
-const NOOP = () => {
-};
-const NO = () => false;
-const onRE = /^on[^a-z]/;
-const isOn = (key) => onRE.test(key);
-const isModelListener = (key) => key.startsWith("onUpdate:");
-const extend = Object.assign;
-const remove = (arr, el) => {
-  const i = arr.indexOf(el);
-  if (i > -1) {
-    arr.splice(i, 1);
-  }
-};
-const hasOwnProperty = Object.prototype.hasOwnProperty;
-const hasOwn = (val, key) => hasOwnProperty.call(val, key);
-const isArray = Array.isArray;
-const isMap = (val) => toTypeString(val) === "[object Map]";
-const isSet = (val) => toTypeString(val) === "[object Set]";
-const isFunction = (val) => typeof val === "function";
-const isString = (val) => typeof val === "string";
-const isSymbol = (val) => typeof val === "symbol";
-const isObject$1 = (val) => val !== null && typeof val === "object";
-const isPromise$1 = (val) => {
-  return isObject$1(val) && isFunction(val.then) && isFunction(val.catch);
-};
-const objectToString = Object.prototype.toString;
-const toTypeString = (value) => objectToString.call(value);
-const toRawType = (value) => {
-  return toTypeString(value).slice(8, -1);
-};
-const isPlainObject = (val) => toTypeString(val) === "[object Object]";
-const isIntegerKey = (key) => isString(key) && key !== "NaN" && key[0] !== "-" && "" + parseInt(key, 10) === key;
-const isReservedProp = /* @__PURE__ */ makeMap(",key,ref,ref_for,ref_key,onVnodeBeforeMount,onVnodeMounted,onVnodeBeforeUpdate,onVnodeUpdated,onVnodeBeforeUnmount,onVnodeUnmounted");
-const isBuiltInDirective = /* @__PURE__ */ makeMap("bind,cloak,else-if,else,for,html,if,model,on,once,pre,show,slot,text,memo");
-const cacheStringFunction = (fn) => {
-  const cache = /* @__PURE__ */ Object.create(null);
-  return (str) => {
-    const hit = cache[str];
-    return hit || (cache[str] = fn(str));
-  };
-};
-const camelizeRE = /-(\w)/g;
-const camelize = cacheStringFunction((str) => {
-  return str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : "");
-});
-const hyphenateRE = /\B([A-Z])/g;
-const hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, "-$1").toLowerCase());
-const capitalize = cacheStringFunction((str) => str.charAt(0).toUpperCase() + str.slice(1));
-const toHandlerKey = cacheStringFunction((str) => str ? `on${capitalize(str)}` : ``);
-const hasChanged = (value, oldValue) => !Object.is(value, oldValue);
-const invokeArrayFns$1 = (fns, arg) => {
-  for (let i = 0; i < fns.length; i++) {
-    fns[i](arg);
-  }
-};
-const def = (obj, key, value) => {
-  Object.defineProperty(obj, key, {
-    configurable: true,
-    enumerable: false,
-    value
-  });
-};
-const toNumber = (val) => {
-  const n2 = parseFloat(val);
-  return isNaN(n2) ? val : n2;
-};
-const LINEFEED = "\n";
-const SLOT_DEFAULT_NAME = "d";
-const ON_SHOW = "onShow";
-const ON_HIDE = "onHide";
-const ON_LAUNCH = "onLaunch";
-const ON_ERROR = "onError";
-const ON_THEME_CHANGE = "onThemeChange";
-const ON_PAGE_NOT_FOUND = "onPageNotFound";
-const ON_UNHANDLE_REJECTION = "onUnhandledRejection";
-const ON_LOAD = "onLoad";
-const ON_READY = "onReady";
-const ON_UNLOAD = "onUnload";
-const ON_INIT = "onInit";
-const ON_SAVE_EXIT_STATE = "onSaveExitState";
-const ON_RESIZE = "onResize";
-const ON_BACK_PRESS = "onBackPress";
-const ON_PAGE_SCROLL = "onPageScroll";
-const ON_TAB_ITEM_TAP = "onTabItemTap";
-const ON_REACH_BOTTOM = "onReachBottom";
-const ON_PULL_DOWN_REFRESH = "onPullDownRefresh";
-const ON_SHARE_TIMELINE = "onShareTimeline";
-const ON_ADD_TO_FAVORITES = "onAddToFavorites";
-const ON_SHARE_APP_MESSAGE = "onShareAppMessage";
-const ON_NAVIGATION_BAR_BUTTON_TAP = "onNavigationBarButtonTap";
-const ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED = "onNavigationBarSearchInputClicked";
-const ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED = "onNavigationBarSearchInputChanged";
-const ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED = "onNavigationBarSearchInputConfirmed";
-const ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED = "onNavigationBarSearchInputFocusChanged";
-const customizeRE = /:/g;
-function customizeEvent(str) {
-  return camelize(str.replace(customizeRE, "-"));
-}
-function hasLeadingSlash(str) {
-  return str.indexOf("/") === 0;
-}
-function addLeadingSlash(str) {
-  return hasLeadingSlash(str) ? str : "/" + str;
-}
-const invokeArrayFns = (fns, arg) => {
-  let ret;
-  for (let i = 0; i < fns.length; i++) {
-    ret = fns[i](arg);
-  }
-  return ret;
-};
-function once(fn, ctx = null) {
-  let res;
-  return (...args) => {
-    if (fn) {
-      res = fn.apply(ctx, args);
-      fn = null;
-    }
-    return res;
-  };
-}
-function getValueByDataPath(obj, path) {
-  if (!isString(path)) {
-    return;
-  }
-  path = path.replace(/\[(\d+)\]/g, ".$1");
-  const parts = path.split(".");
-  let key = parts[0];
-  if (!obj) {
-    obj = {};
-  }
-  if (parts.length === 1) {
-    return obj[key];
-  }
-  return getValueByDataPath(obj[key], parts.slice(1).join("."));
-}
-function sortObject(obj) {
-  let sortObj = {};
-  if (isPlainObject(obj)) {
-    Object.keys(obj).sort().forEach((key) => {
-      const _key = key;
-      sortObj[_key] = obj[_key];
-    });
-  }
-  return !Object.keys(sortObj) ? obj : sortObj;
-}
-const encode = encodeURIComponent;
-function stringifyQuery(obj, encodeStr = encode) {
-  const res = obj ? Object.keys(obj).map((key) => {
-    let val = obj[key];
-    if (typeof val === void 0 || val === null) {
-      val = "";
-    } else if (isPlainObject(val)) {
-      val = JSON.stringify(val);
-    }
-    return encodeStr(key) + "=" + encodeStr(val);
-  }).filter((x) => x.length > 0).join("&") : null;
-  return res ? `?${res}` : "";
-}
-const PAGE_HOOKS = [
-  ON_INIT,
-  ON_LOAD,
-  ON_SHOW,
-  ON_HIDE,
-  ON_UNLOAD,
-  ON_BACK_PRESS,
-  ON_PAGE_SCROLL,
-  ON_TAB_ITEM_TAP,
-  ON_REACH_BOTTOM,
-  ON_PULL_DOWN_REFRESH,
-  ON_SHARE_TIMELINE,
-  ON_SHARE_APP_MESSAGE,
-  ON_ADD_TO_FAVORITES,
-  ON_SAVE_EXIT_STATE,
-  ON_NAVIGATION_BAR_BUTTON_TAP,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED
-];
-function isRootHook(name) {
-  return PAGE_HOOKS.indexOf(name) > -1;
-}
-const UniLifecycleHooks = [
-  ON_SHOW,
-  ON_HIDE,
-  ON_LAUNCH,
-  ON_ERROR,
-  ON_THEME_CHANGE,
-  ON_PAGE_NOT_FOUND,
-  ON_UNHANDLE_REJECTION,
-  ON_INIT,
-  ON_LOAD,
-  ON_READY,
-  ON_UNLOAD,
-  ON_RESIZE,
-  ON_BACK_PRESS,
-  ON_PAGE_SCROLL,
-  ON_TAB_ITEM_TAP,
-  ON_REACH_BOTTOM,
-  ON_PULL_DOWN_REFRESH,
-  ON_SHARE_TIMELINE,
-  ON_ADD_TO_FAVORITES,
-  ON_SHARE_APP_MESSAGE,
-  ON_SAVE_EXIT_STATE,
-  ON_NAVIGATION_BAR_BUTTON_TAP,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_CLICKED,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_CHANGED,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_CONFIRMED,
-  ON_NAVIGATION_BAR_SEARCH_INPUT_FOCUS_CHANGED
-];
-const MINI_PROGRAM_PAGE_RUNTIME_HOOKS = /* @__PURE__ */ (() => {
-  return {
-    onPageScroll: 1,
-    onShareAppMessage: 1 << 1,
-    onShareTimeline: 1 << 2
-  };
-})();
-let vueApp;
-const createVueAppHooks = [];
-function onCreateVueApp(hook) {
-  if (vueApp) {
-    return hook(vueApp);
-  }
-  createVueAppHooks.push(hook);
-}
-function invokeCreateVueAppHook(app) {
-  vueApp = app;
-  createVueAppHooks.forEach((hook) => hook(app));
-}
-const E = function() {
-};
-E.prototype = {
-  on: function(name, callback, ctx) {
-    var e2 = this.e || (this.e = {});
-    (e2[name] || (e2[name] = [])).push({
-      fn: callback,
-      ctx
-    });
-    return this;
-  },
-  once: function(name, callback, ctx) {
-    var self2 = this;
-    function listener() {
-      self2.off(name, listener);
-      callback.apply(ctx, arguments);
-    }
-    listener._ = callback;
-    return this.on(name, listener, ctx);
-  },
-  emit: function(name) {
-    var data = [].slice.call(arguments, 1);
-    var evtArr = ((this.e || (this.e = {}))[name] || []).slice();
-    var i = 0;
-    var len = evtArr.length;
-    for (i; i < len; i++) {
-      evtArr[i].fn.apply(evtArr[i].ctx, data);
-    }
-    return this;
-  },
-  off: function(name, callback) {
-    var e2 = this.e || (this.e = {});
-    var evts = e2[name];
-    var liveEvents = [];
-    if (evts && callback) {
-      for (var i = 0, len = evts.length; i < len; i++) {
-        if (evts[i].fn !== callback && evts[i].fn._ !== callback)
-          liveEvents.push(evts[i]);
-      }
-    }
-    liveEvents.length ? e2[name] = liveEvents : delete e2[name];
-    return this;
-  }
-};
-var E$1 = E;
-const LOCALE_ZH_HANS = "zh-Hans";
-const LOCALE_ZH_HANT = "zh-Hant";
-const LOCALE_EN = "en";
-const LOCALE_FR = "fr";
-const LOCALE_ES = "es";
-function include(str, parts) {
-  return !!parts.find((part) => str.indexOf(part) !== -1);
-}
-function startsWith(str, parts) {
-  return parts.find((part) => str.indexOf(part) === 0);
-}
-function normalizeLocale(locale, messages) {
-  if (!locale) {
-    return;
-  }
-  locale = locale.trim().replace(/_/g, "-");
-  if (messages && messages[locale]) {
-    return locale;
-  }
-  locale = locale.toLowerCase();
-  if (locale === "chinese") {
-    return LOCALE_ZH_HANS;
-  }
-  if (locale.indexOf("zh") === 0) {
-    if (locale.indexOf("-hans") > -1) {
-      return LOCALE_ZH_HANS;
-    }
-    if (locale.indexOf("-hant") > -1) {
-      return LOCALE_ZH_HANT;
-    }
-    if (include(locale, ["-tw", "-hk", "-mo", "-cht"])) {
-      return LOCALE_ZH_HANT;
-    }
-    return LOCALE_ZH_HANS;
-  }
-  const lang = startsWith(locale, [LOCALE_EN, LOCALE_FR, LOCALE_ES]);
-  if (lang) {
-    return lang;
-  }
-}
-function getBaseSystemInfo() {
-  return wx.getSystemInfoSync();
-}
-function validateProtocolFail(name, msg) {
-  console.warn(`${name}: ${msg}`);
-}
-function validateProtocol(name, data, protocol, onFail) {
-  if (!onFail) {
-    onFail = validateProtocolFail;
-  }
-  for (const key in protocol) {
-    const errMsg = validateProp$1(key, data[key], protocol[key], !hasOwn(data, key));
-    if (isString(errMsg)) {
-      onFail(name, errMsg);
-    }
-  }
-}
-function validateProtocols(name, args, protocol, onFail) {
-  if (!protocol) {
-    return;
-  }
-  if (!isArray(protocol)) {
-    return validateProtocol(name, args[0] || /* @__PURE__ */ Object.create(null), protocol, onFail);
-  }
-  const len = protocol.length;
-  const argsLen = args.length;
-  for (let i = 0; i < len; i++) {
-    const opts = protocol[i];
-    const data = /* @__PURE__ */ Object.create(null);
-    if (argsLen > i) {
-      data[opts.name] = args[i];
-    }
-    validateProtocol(name, data, { [opts.name]: opts }, onFail);
-  }
-}
-function validateProp$1(name, value, prop, isAbsent) {
-  if (!isPlainObject(prop)) {
-    prop = { type: prop };
-  }
-  const { type, required, validator } = prop;
-  if (required && isAbsent) {
-    return 'Missing required args: "' + name + '"';
-  }
-  if (value == null && !required) {
-    return;
-  }
-  if (type != null) {
-    let isValid = false;
-    const types = isArray(type) ? type : [type];
-    const expectedTypes = [];
-    for (let i = 0; i < types.length && !isValid; i++) {
-      const { valid, expectedType } = assertType$1(value, types[i]);
-      expectedTypes.push(expectedType || "");
-      isValid = valid;
-    }
-    if (!isValid) {
-      return getInvalidTypeMessage$1(name, value, expectedTypes);
-    }
-  }
-  if (validator) {
-    return validator(value);
-  }
-}
-const isSimpleType$1 = /* @__PURE__ */ makeMap("String,Number,Boolean,Function,Symbol");
-function assertType$1(value, type) {
-  let valid;
-  const expectedType = getType$1(type);
-  if (isSimpleType$1(expectedType)) {
-    const t2 = typeof value;
-    valid = t2 === expectedType.toLowerCase();
-    if (!valid && t2 === "object") {
-      valid = value instanceof type;
-    }
-  } else if (expectedType === "Object") {
-    valid = isObject$1(value);
-  } else if (expectedType === "Array") {
-    valid = isArray(value);
-  } else {
-    {
-      valid = value instanceof type;
-    }
-  }
-  return {
-    valid,
-    expectedType
-  };
-}
-function getInvalidTypeMessage$1(name, value, expectedTypes) {
-  let message = `Invalid args: type check failed for args "${name}". Expected ${expectedTypes.map(capitalize).join(", ")}`;
-  const expectedType = expectedTypes[0];
-  const receivedType = toRawType(value);
-  const expectedValue = styleValue$1(value, expectedType);
-  const receivedValue = styleValue$1(value, receivedType);
-  if (expectedTypes.length === 1 && isExplicable$1(expectedType) && !isBoolean$1(expectedType, receivedType)) {
-    message += ` with value ${expectedValue}`;
-  }
-  message += `, got ${receivedType} `;
-  if (isExplicable$1(receivedType)) {
-    message += `with value ${receivedValue}.`;
-  }
-  return message;
-}
-function getType$1(ctor) {
-  const match = ctor && ctor.toString().match(/^\s*function (\w+)/);
-  return match ? match[1] : "";
-}
-function styleValue$1(value, type) {
-  if (type === "String") {
-    return `"${value}"`;
-  } else if (type === "Number") {
-    return `${Number(value)}`;
-  } else {
-    return `${value}`;
-  }
-}
-function isExplicable$1(type) {
-  const explicitTypes = ["string", "number", "boolean"];
-  return explicitTypes.some((elem) => type.toLowerCase() === elem);
-}
-function isBoolean$1(...args) {
-  return args.some((elem) => elem.toLowerCase() === "boolean");
-}
-function tryCatch(fn) {
-  return function() {
-    try {
-      return fn.apply(fn, arguments);
-    } catch (e2) {
-      console.error(e2);
-    }
-  };
-}
-let invokeCallbackId = 1;
-const invokeCallbacks = {};
-function addInvokeCallback(id, name, callback, keepAlive = false) {
-  invokeCallbacks[id] = {
-    name,
-    keepAlive,
-    callback
-  };
-  return id;
-}
-function invokeCallback(id, res, extras) {
-  if (typeof id === "number") {
-    const opts = invokeCallbacks[id];
-    if (opts) {
-      if (!opts.keepAlive) {
-        delete invokeCallbacks[id];
-      }
-      return opts.callback(res, extras);
-    }
-  }
-  return res;
-}
-const API_SUCCESS = "success";
-const API_FAIL = "fail";
-const API_COMPLETE = "complete";
-function getApiCallbacks(args) {
-  const apiCallbacks = {};
-  for (const name in args) {
-    const fn = args[name];
-    if (isFunction(fn)) {
-      apiCallbacks[name] = tryCatch(fn);
-      delete args[name];
-    }
-  }
-  return apiCallbacks;
-}
-function normalizeErrMsg$1(errMsg, name) {
-  if (!errMsg || errMsg.indexOf(":fail") === -1) {
-    return name + ":ok";
-  }
-  return name + errMsg.substring(errMsg.indexOf(":fail"));
-}
-function createAsyncApiCallback(name, args = {}, { beforeAll, beforeSuccess } = {}) {
-  if (!isPlainObject(args)) {
-    args = {};
-  }
-  const { success, fail, complete } = getApiCallbacks(args);
-  const hasSuccess = isFunction(success);
-  const hasFail = isFunction(fail);
-  const hasComplete = isFunction(complete);
-  const callbackId = invokeCallbackId++;
-  addInvokeCallback(callbackId, name, (res) => {
-    res = res || {};
-    res.errMsg = normalizeErrMsg$1(res.errMsg, name);
-    isFunction(beforeAll) && beforeAll(res);
-    if (res.errMsg === name + ":ok") {
-      isFunction(beforeSuccess) && beforeSuccess(res, args);
-      hasSuccess && success(res);
-    } else {
-      hasFail && fail(res);
-    }
-    hasComplete && complete(res);
-  });
-  return callbackId;
-}
-const HOOK_SUCCESS = "success";
-const HOOK_FAIL = "fail";
-const HOOK_COMPLETE = "complete";
-const globalInterceptors = {};
-const scopedInterceptors = {};
-function wrapperHook(hook) {
-  return function(data) {
-    return hook(data) || data;
-  };
-}
-function queue$1(hooks, data) {
-  let promise = false;
-  for (let i = 0; i < hooks.length; i++) {
-    const hook = hooks[i];
-    if (promise) {
-      promise = Promise.resolve(wrapperHook(hook));
-    } else {
-      const res = hook(data);
-      if (isPromise$1(res)) {
-        promise = Promise.resolve(res);
-      }
-      if (res === false) {
-        return {
-          then() {
-          },
-          catch() {
-          }
-        };
-      }
-    }
-  }
-  return promise || {
-    then(callback) {
-      return callback(data);
-    },
-    catch() {
-    }
-  };
-}
-function wrapperOptions(interceptors2, options = {}) {
-  [HOOK_SUCCESS, HOOK_FAIL, HOOK_COMPLETE].forEach((name) => {
-    const hooks = interceptors2[name];
-    if (!isArray(hooks)) {
-      return;
-    }
-    const oldCallback = options[name];
-    options[name] = function callbackInterceptor(res) {
-      queue$1(hooks, res).then((res2) => {
-        return isFunction(oldCallback) && oldCallback(res2) || res2;
-      });
-    };
-  });
-  return options;
-}
-function wrapperReturnValue(method, returnValue) {
-  const returnValueHooks = [];
-  if (isArray(globalInterceptors.returnValue)) {
-    returnValueHooks.push(...globalInterceptors.returnValue);
-  }
-  const interceptor = scopedInterceptors[method];
-  if (interceptor && isArray(interceptor.returnValue)) {
-    returnValueHooks.push(...interceptor.returnValue);
-  }
-  returnValueHooks.forEach((hook) => {
-    returnValue = hook(returnValue) || returnValue;
-  });
-  return returnValue;
-}
-function getApiInterceptorHooks(method) {
-  const interceptor = /* @__PURE__ */ Object.create(null);
-  Object.keys(globalInterceptors).forEach((hook) => {
-    if (hook !== "returnValue") {
-      interceptor[hook] = globalInterceptors[hook].slice();
-    }
-  });
-  const scopedInterceptor = scopedInterceptors[method];
-  if (scopedInterceptor) {
-    Object.keys(scopedInterceptor).forEach((hook) => {
-      if (hook !== "returnValue") {
-        interceptor[hook] = (interceptor[hook] || []).concat(scopedInterceptor[hook]);
-      }
-    });
-  }
-  return interceptor;
-}
-function invokeApi(method, api, options, params) {
-  const interceptor = getApiInterceptorHooks(method);
-  if (interceptor && Object.keys(interceptor).length) {
-    if (isArray(interceptor.invoke)) {
-      const res = queue$1(interceptor.invoke, options);
-      return res.then((options2) => {
-        return api(wrapperOptions(interceptor, options2), ...params);
-      });
-    } else {
-      return api(wrapperOptions(interceptor, options), ...params);
-    }
-  }
-  return api(options, ...params);
-}
-function hasCallback(args) {
-  if (isPlainObject(args) && [API_SUCCESS, API_FAIL, API_COMPLETE].find((cb) => isFunction(args[cb]))) {
-    return true;
-  }
-  return false;
-}
-function handlePromise(promise) {
-  return promise;
-}
-function promisify$1(name, fn) {
-  return (args = {}, ...rest) => {
-    if (hasCallback(args)) {
-      return wrapperReturnValue(name, invokeApi(name, fn, args, rest));
-    }
-    return wrapperReturnValue(name, handlePromise(new Promise((resolve2, reject) => {
-      invokeApi(name, fn, extend(args, { success: resolve2, fail: reject }), rest);
-    })));
-  };
-}
-function formatApiArgs(args, options) {
-  const params = args[0];
-  if (!options || !isPlainObject(options.formatArgs) && isPlainObject(params)) {
-    return;
-  }
-  const formatArgs = options.formatArgs;
-  const keys = Object.keys(formatArgs);
-  for (let i = 0; i < keys.length; i++) {
-    const name = keys[i];
-    const formatterOrDefaultValue = formatArgs[name];
-    if (isFunction(formatterOrDefaultValue)) {
-      const errMsg = formatterOrDefaultValue(args[0][name], params);
-      if (isString(errMsg)) {
-        return errMsg;
-      }
-    } else {
-      if (!hasOwn(params, name)) {
-        params[name] = formatterOrDefaultValue;
-      }
-    }
-  }
-}
-function invokeSuccess(id, name, res) {
-  return invokeCallback(id, extend(res || {}, { errMsg: name + ":ok" }));
-}
-function invokeFail(id, name, errMsg, errRes) {
-  return invokeCallback(id, extend({ errMsg: name + ":fail" + (errMsg ? " " + errMsg : "") }, errRes));
-}
-function beforeInvokeApi(name, args, protocol, options) {
-  {
-    validateProtocols(name, args, protocol);
-  }
-  if (options && options.beforeInvoke) {
-    const errMsg2 = options.beforeInvoke(args);
-    if (isString(errMsg2)) {
-      return errMsg2;
-    }
-  }
-  const errMsg = formatApiArgs(args, options);
-  if (errMsg) {
-    return errMsg;
-  }
-}
-function normalizeErrMsg(errMsg) {
-  if (!errMsg || isString(errMsg)) {
-    return errMsg;
-  }
-  if (errMsg.stack) {
-    console.error(errMsg.message + LINEFEED + errMsg.stack);
-    return errMsg.message;
-  }
-  return errMsg;
-}
-function wrapperTaskApi(name, fn, protocol, options) {
-  return (args) => {
-    const id = createAsyncApiCallback(name, args, options);
-    const errMsg = beforeInvokeApi(name, [args], protocol, options);
-    if (errMsg) {
-      return invokeFail(id, name, errMsg);
-    }
-    return fn(args, {
-      resolve: (res) => invokeSuccess(id, name, res),
-      reject: (errMsg2, errRes) => invokeFail(id, name, normalizeErrMsg(errMsg2), errRes)
-    });
-  };
-}
-function wrapperSyncApi(name, fn, protocol, options) {
-  return (...args) => {
-    const errMsg = beforeInvokeApi(name, args, protocol, options);
-    if (errMsg) {
-      throw new Error(errMsg);
-    }
-    return fn.apply(null, args);
-  };
-}
-function wrapperAsyncApi(name, fn, protocol, options) {
-  return wrapperTaskApi(name, fn, protocol, options);
-}
-function defineSyncApi(name, fn, protocol, options) {
-  return wrapperSyncApi(name, fn, protocol, options);
-}
-function defineAsyncApi(name, fn, protocol, options) {
-  return promisify$1(name, wrapperAsyncApi(name, fn, protocol, options));
-}
-const API_UPX2PX = "upx2px";
-const Upx2pxProtocol = [
-  {
-    name: "upx",
-    type: [Number, String],
-    required: true
-  }
-];
-const EPS = 1e-4;
-const BASE_DEVICE_WIDTH = 750;
-let isIOS = false;
-let deviceWidth = 0;
-let deviceDPR = 0;
-function checkDeviceWidth() {
-  const { platform, pixelRatio, windowWidth } = getBaseSystemInfo();
-  deviceWidth = windowWidth;
-  deviceDPR = pixelRatio;
-  isIOS = platform === "ios";
-}
-const upx2px = defineSyncApi(API_UPX2PX, (number, newDeviceWidth) => {
-  if (deviceWidth === 0) {
-    checkDeviceWidth();
-  }
-  number = Number(number);
-  if (number === 0) {
-    return 0;
-  }
-  let width = newDeviceWidth || deviceWidth;
-  let result = number / BASE_DEVICE_WIDTH * width;
-  if (result < 0) {
-    result = -result;
-  }
-  result = Math.floor(result + EPS);
-  if (result === 0) {
-    if (deviceDPR === 1 || !isIOS) {
-      result = 1;
-    } else {
-      result = 0.5;
-    }
-  }
-  return number < 0 ? -result : result;
-}, Upx2pxProtocol);
-const API_ADD_INTERCEPTOR = "addInterceptor";
-const API_REMOVE_INTERCEPTOR = "removeInterceptor";
-const AddInterceptorProtocol = [
-  {
-    name: "method",
-    type: [String, Object],
-    required: true
-  }
-];
-const RemoveInterceptorProtocol = AddInterceptorProtocol;
-function mergeInterceptorHook(interceptors2, interceptor) {
-  Object.keys(interceptor).forEach((hook) => {
-    if (isFunction(interceptor[hook])) {
-      interceptors2[hook] = mergeHook(interceptors2[hook], interceptor[hook]);
-    }
-  });
-}
-function removeInterceptorHook(interceptors2, interceptor) {
-  if (!interceptors2 || !interceptor) {
-    return;
-  }
-  Object.keys(interceptor).forEach((name) => {
-    const hooks = interceptors2[name];
-    const hook = interceptor[name];
-    if (isArray(hooks) && isFunction(hook)) {
-      remove(hooks, hook);
-    }
-  });
-}
-function mergeHook(parentVal, childVal) {
-  const res = childVal ? parentVal ? parentVal.concat(childVal) : isArray(childVal) ? childVal : [childVal] : parentVal;
-  return res ? dedupeHooks(res) : res;
-}
-function dedupeHooks(hooks) {
-  const res = [];
-  for (let i = 0; i < hooks.length; i++) {
-    if (res.indexOf(hooks[i]) === -1) {
-      res.push(hooks[i]);
-    }
-  }
-  return res;
-}
-const addInterceptor = defineSyncApi(API_ADD_INTERCEPTOR, (method, interceptor) => {
-  if (isString(method) && isPlainObject(interceptor)) {
-    mergeInterceptorHook(scopedInterceptors[method] || (scopedInterceptors[method] = {}), interceptor);
-  } else if (isPlainObject(method)) {
-    mergeInterceptorHook(globalInterceptors, method);
-  }
-}, AddInterceptorProtocol);
-const removeInterceptor = defineSyncApi(API_REMOVE_INTERCEPTOR, (method, interceptor) => {
-  if (isString(method)) {
-    if (isPlainObject(interceptor)) {
-      removeInterceptorHook(scopedInterceptors[method], interceptor);
-    } else {
-      delete scopedInterceptors[method];
-    }
-  } else if (isPlainObject(method)) {
-    removeInterceptorHook(globalInterceptors, method);
-  }
-}, RemoveInterceptorProtocol);
-const interceptors = {};
-const API_ON = "$on";
-const OnProtocol = [
-  {
-    name: "event",
-    type: String,
-    required: true
-  },
-  {
-    name: "callback",
-    type: Function,
-    required: true
-  }
-];
-const API_ONCE = "$once";
-const OnceProtocol = OnProtocol;
-const API_OFF = "$off";
-const OffProtocol = [
-  {
-    name: "event",
-    type: [String, Array]
-  },
-  {
-    name: "callback",
-    type: Function
-  }
-];
-const API_EMIT = "$emit";
-const EmitProtocol = [
-  {
-    name: "event",
-    type: String,
-    required: true
-  }
-];
-const emitter = new E$1();
-const $on = defineSyncApi(API_ON, (name, callback) => {
-  emitter.on(name, callback);
-  return () => emitter.off(name, callback);
-}, OnProtocol);
-const $once = defineSyncApi(API_ONCE, (name, callback) => {
-  emitter.once(name, callback);
-  return () => emitter.off(name, callback);
-}, OnceProtocol);
-const $off = defineSyncApi(API_OFF, (name, callback) => {
-  if (!name) {
-    emitter.e = {};
-    return;
-  }
-  if (!isArray(name))
-    name = [name];
-  name.forEach((n2) => emitter.off(n2, callback));
-}, OffProtocol);
-const $emit = defineSyncApi(API_EMIT, (name, ...args) => {
-  emitter.emit(name, ...args);
-}, EmitProtocol);
-let cid;
-let cidErrMsg;
-let enabled;
-function normalizePushMessage(message) {
-  try {
-    return JSON.parse(message);
-  } catch (e2) {
-  }
-  return message;
-}
-function invokePushCallback(args) {
-  if (args.type === "enabled") {
-    enabled = true;
-  } else if (args.type === "clientId") {
-    cid = args.cid;
-    cidErrMsg = args.errMsg;
-    invokeGetPushCidCallbacks(cid, args.errMsg);
-  } else if (args.type === "pushMsg") {
-    const message = {
-      type: "receive",
-      data: normalizePushMessage(args.message)
-    };
-    for (let i = 0; i < onPushMessageCallbacks.length; i++) {
-      const callback = onPushMessageCallbacks[i];
-      callback(message);
-      if (message.stopped) {
-        break;
-      }
-    }
-  } else if (args.type === "click") {
-    onPushMessageCallbacks.forEach((callback) => {
-      callback({
-        type: "click",
-        data: normalizePushMessage(args.message)
-      });
-    });
-  }
-}
-const getPushCidCallbacks = [];
-function invokeGetPushCidCallbacks(cid2, errMsg) {
-  getPushCidCallbacks.forEach((callback) => {
-    callback(cid2, errMsg);
-  });
-  getPushCidCallbacks.length = 0;
-}
-const API_GET_PUSH_CLIENT_ID = "getPushClientId";
-const getPushClientId = defineAsyncApi(API_GET_PUSH_CLIENT_ID, (_, { resolve: resolve2, reject }) => {
-  Promise.resolve().then(() => {
-    if (typeof enabled === "undefined") {
-      enabled = false;
-      cid = "";
-      cidErrMsg = "uniPush is not enabled";
-    }
-    getPushCidCallbacks.push((cid2, errMsg) => {
-      if (cid2) {
-        resolve2({ cid: cid2 });
-      } else {
-        reject(errMsg);
-      }
-    });
-    if (typeof cid !== "undefined") {
-      invokeGetPushCidCallbacks(cid, cidErrMsg);
-    }
-  });
-});
-const onPushMessageCallbacks = [];
-const onPushMessage = (fn) => {
-  if (onPushMessageCallbacks.indexOf(fn) === -1) {
-    onPushMessageCallbacks.push(fn);
-  }
-};
-const offPushMessage = (fn) => {
-  if (!fn) {
-    onPushMessageCallbacks.length = 0;
-  } else {
-    const index2 = onPushMessageCallbacks.indexOf(fn);
-    if (index2 > -1) {
-      onPushMessageCallbacks.splice(index2, 1);
-    }
-  }
-};
-const SYNC_API_RE = /^\$|getLocale|setLocale|sendNativeEvent|restoreGlobal|requireGlobal|getCurrentSubNVue|getMenuButtonBoundingClientRect|^report|interceptors|Interceptor$|getSubNVueById|requireNativePlugin|upx2px|hideKeyboard|canIUse|^create|Sync$|Manager$|base64ToArrayBuffer|arrayBufferToBase64|getDeviceInfo|getAppBaseInfo|getWindowInfo|getSystemSetting|getAppAuthorizeSetting/;
-const CONTEXT_API_RE = /^create|Manager$/;
-const CONTEXT_API_RE_EXC = ["createBLEConnection"];
-const ASYNC_API = ["createBLEConnection"];
-const CALLBACK_API_RE = /^on|^off/;
-function isContextApi(name) {
-  return CONTEXT_API_RE.test(name) && CONTEXT_API_RE_EXC.indexOf(name) === -1;
-}
-function isSyncApi(name) {
-  return SYNC_API_RE.test(name) && ASYNC_API.indexOf(name) === -1;
-}
-function isCallbackApi(name) {
-  return CALLBACK_API_RE.test(name) && name !== "onPush";
-}
-function shouldPromise(name) {
-  if (isContextApi(name) || isSyncApi(name) || isCallbackApi(name)) {
-    return false;
-  }
-  return true;
-}
-if (!Promise.prototype.finally) {
-  Promise.prototype.finally = function(onfinally) {
-    const promise = this.constructor;
-    return this.then((value) => promise.resolve(onfinally && onfinally()).then(() => value), (reason) => promise.resolve(onfinally && onfinally()).then(() => {
-      throw reason;
-    }));
-  };
-}
-function promisify(name, api) {
-  if (!shouldPromise(name)) {
-    return api;
-  }
-  if (!isFunction(api)) {
-    return api;
-  }
-  return function promiseApi(options = {}, ...rest) {
-    if (isFunction(options.success) || isFunction(options.fail) || isFunction(options.complete)) {
-      return wrapperReturnValue(name, invokeApi(name, api, options, rest));
-    }
-    return wrapperReturnValue(name, handlePromise(new Promise((resolve2, reject) => {
-      invokeApi(name, api, extend({}, options, {
-        success: resolve2,
-        fail: reject
-      }), rest);
-    })));
-  };
-}
-const CALLBACKS = ["success", "fail", "cancel", "complete"];
-function initWrapper(protocols2) {
-  function processCallback(methodName, method, returnValue) {
-    return function(res) {
-      return method(processReturnValue(methodName, res, returnValue));
-    };
-  }
-  function processArgs(methodName, fromArgs, argsOption = {}, returnValue = {}, keepFromArgs = false) {
-    if (isPlainObject(fromArgs)) {
-      const toArgs = keepFromArgs === true ? fromArgs : {};
-      if (isFunction(argsOption)) {
-        argsOption = argsOption(fromArgs, toArgs) || {};
-      }
-      for (const key in fromArgs) {
-        if (hasOwn(argsOption, key)) {
-          let keyOption = argsOption[key];
-          if (isFunction(keyOption)) {
-            keyOption = keyOption(fromArgs[key], fromArgs, toArgs);
-          }
-          if (!keyOption) {
-            console.warn(`\u5FAE\u4FE1\u5C0F\u7A0B\u5E8F ${methodName} \u6682\u4E0D\u652F\u6301 ${key}`);
-          } else if (isString(keyOption)) {
-            toArgs[keyOption] = fromArgs[key];
-          } else if (isPlainObject(keyOption)) {
-            toArgs[keyOption.name ? keyOption.name : key] = keyOption.value;
-          }
-        } else if (CALLBACKS.indexOf(key) !== -1) {
-          const callback = fromArgs[key];
-          if (isFunction(callback)) {
-            toArgs[key] = processCallback(methodName, callback, returnValue);
-          }
-        } else {
-          if (!keepFromArgs && !hasOwn(toArgs, key)) {
-            toArgs[key] = fromArgs[key];
-          }
-        }
-      }
-      return toArgs;
-    } else if (isFunction(fromArgs)) {
-      fromArgs = processCallback(methodName, fromArgs, returnValue);
-    }
-    return fromArgs;
-  }
-  function processReturnValue(methodName, res, returnValue, keepReturnValue = false) {
-    if (isFunction(protocols2.returnValue)) {
-      res = protocols2.returnValue(methodName, res);
-    }
-    return processArgs(methodName, res, returnValue, {}, keepReturnValue);
-  }
-  return function wrapper(methodName, method) {
-    if (!hasOwn(protocols2, methodName)) {
-      return method;
-    }
-    const protocol = protocols2[methodName];
-    if (!protocol) {
-      return function() {
-        console.error(`\u5FAE\u4FE1\u5C0F\u7A0B\u5E8F \u6682\u4E0D\u652F\u6301${methodName}`);
-      };
-    }
-    return function(arg1, arg2) {
-      let options = protocol;
-      if (isFunction(protocol)) {
-        options = protocol(arg1);
-      }
-      arg1 = processArgs(methodName, arg1, options.args, options.returnValue);
-      const args = [arg1];
-      if (typeof arg2 !== "undefined") {
-        args.push(arg2);
-      }
-      const returnValue = wx[options.name || methodName].apply(wx, args);
-      if (isSyncApi(methodName)) {
-        return processReturnValue(methodName, returnValue, options.returnValue, isContextApi(methodName));
-      }
-      return returnValue;
-    };
-  };
-}
-const getLocale = () => {
-  const app = getApp({ allowDefault: true });
-  if (app && app.$vm) {
-    return app.$vm.$locale;
-  }
-  return normalizeLocale(wx.getSystemInfoSync().language) || LOCALE_EN;
-};
-const setLocale = (locale) => {
-  const app = getApp();
-  if (!app) {
-    return false;
-  }
-  const oldLocale = app.$vm.$locale;
-  if (oldLocale !== locale) {
-    app.$vm.$locale = locale;
-    onLocaleChangeCallbacks.forEach((fn) => fn({ locale }));
-    return true;
-  }
-  return false;
-};
-const onLocaleChangeCallbacks = [];
-const onLocaleChange = (fn) => {
-  if (onLocaleChangeCallbacks.indexOf(fn) === -1) {
-    onLocaleChangeCallbacks.push(fn);
-  }
-};
-if (typeof global !== "undefined") {
-  global.getLocale = getLocale;
-}
-const baseApis = {
-  $on,
-  $off,
-  $once,
-  $emit,
-  upx2px,
-  interceptors,
-  addInterceptor,
-  removeInterceptor,
-  onCreateVueApp,
-  invokeCreateVueAppHook,
-  getLocale,
-  setLocale,
-  onLocaleChange,
-  getPushClientId,
-  onPushMessage,
-  offPushMessage,
-  invokePushCallback
-};
-function initUni(api, protocols2) {
-  const wrapper = initWrapper(protocols2);
-  const UniProxyHandlers = {
-    get(target, key) {
-      if (hasOwn(target, key)) {
-        return target[key];
-      }
-      if (hasOwn(api, key)) {
-        return promisify(key, api[key]);
-      }
-      if (hasOwn(baseApis, key)) {
-        return promisify(key, baseApis[key]);
-      }
-      return promisify(key, wrapper(key, wx[key]));
-    }
-  };
-  return new Proxy({}, UniProxyHandlers);
-}
-function initGetProvider(providers) {
-  return function getProvider2({ service, success, fail, complete }) {
-    let res;
-    if (providers[service]) {
-      res = {
-        errMsg: "getProvider:ok",
-        service,
-        provider: providers[service]
-      };
-      isFunction(success) && success(res);
-    } else {
-      res = {
-        errMsg: "getProvider:fail:\u670D\u52A1[" + service + "]\u4E0D\u5B58\u5728"
-      };
-      isFunction(fail) && fail(res);
-    }
-    isFunction(complete) && complete(res);
-  };
-}
-const UUID_KEY = "__DC_STAT_UUID";
-let deviceId;
-function useDeviceId(global2 = wx) {
-  return function addDeviceId(_, toRes) {
-    deviceId = deviceId || global2.getStorageSync(UUID_KEY);
-    if (!deviceId) {
-      deviceId = Date.now() + "" + Math.floor(Math.random() * 1e7);
-      wx.setStorage({
-        key: UUID_KEY,
-        data: deviceId
-      });
-    }
-    toRes.deviceId = deviceId;
-  };
-}
-function addSafeAreaInsets(fromRes, toRes) {
-  if (fromRes.safeArea) {
-    const safeArea = fromRes.safeArea;
-    toRes.safeAreaInsets = {
-      top: safeArea.top,
-      left: safeArea.left,
-      right: fromRes.windowWidth - safeArea.right,
-      bottom: fromRes.screenHeight - safeArea.bottom
-    };
-  }
-}
-function populateParameters(fromRes, toRes) {
-  const { brand = "", model = "", system = "", language = "", theme, version: version2, platform, fontSizeSetting, SDKVersion, pixelRatio, deviceOrientation } = fromRes;
-  let osName = "";
-  let osVersion = "";
-  {
-    osName = system.split(" ")[0] || "";
-    osVersion = system.split(" ")[1] || "";
-  }
-  let hostVersion = version2;
-  let deviceType = getGetDeviceType(fromRes, model);
-  let deviceBrand = getDeviceBrand(brand);
-  let _hostName = getHostName(fromRes);
-  let _deviceOrientation = deviceOrientation;
-  let _devicePixelRatio = pixelRatio;
-  let _SDKVersion = SDKVersion;
-  const hostLanguage = language.replace(/_/g, "-");
-  const parameters = {
-    appId: "__UNI__61DDDA4",
-    appName: "his_user_app",
-    appVersion: "1.0.0",
-    appVersionCode: "100",
-    appLanguage: getAppLanguage(hostLanguage),
-    uniCompileVersion: "3.6.4",
-    uniRuntimeVersion: "3.6.4",
-    uniPlatform: "mp-weixin",
-    deviceBrand,
-    deviceModel: model,
-    deviceType,
-    devicePixelRatio: _devicePixelRatio,
-    deviceOrientation: _deviceOrientation,
-    osName: osName.toLocaleLowerCase(),
-    osVersion,
-    hostTheme: theme,
-    hostVersion,
-    hostLanguage,
-    hostName: _hostName,
-    hostSDKVersion: _SDKVersion,
-    hostFontSizeSetting: fontSizeSetting,
-    windowTop: 0,
-    windowBottom: 0,
-    osLanguage: void 0,
-    osTheme: void 0,
-    ua: void 0,
-    hostPackageName: void 0,
-    browserName: void 0,
-    browserVersion: void 0
-  };
-  extend(toRes, parameters);
-}
-function getGetDeviceType(fromRes, model) {
-  let deviceType = fromRes.deviceType || "phone";
-  {
-    const deviceTypeMaps = {
-      ipad: "pad",
-      windows: "pc",
-      mac: "pc"
-    };
-    const deviceTypeMapsKeys = Object.keys(deviceTypeMaps);
-    const _model = model.toLocaleLowerCase();
-    for (let index2 = 0; index2 < deviceTypeMapsKeys.length; index2++) {
-      const _m = deviceTypeMapsKeys[index2];
-      if (_model.indexOf(_m) !== -1) {
-        deviceType = deviceTypeMaps[_m];
-        break;
-      }
-    }
-  }
-  return deviceType;
-}
-function getDeviceBrand(brand) {
-  let deviceBrand = brand;
-  if (deviceBrand) {
-    deviceBrand = deviceBrand.toLocaleLowerCase();
-  }
-  return deviceBrand;
-}
-function getAppLanguage(defaultLanguage) {
-  return getLocale ? getLocale() : defaultLanguage;
-}
-function getHostName(fromRes) {
-  const _platform = "WeChat";
-  let _hostName = fromRes.hostName || _platform;
-  {
-    if (fromRes.environment) {
-      _hostName = fromRes.environment;
-    } else if (fromRes.host && fromRes.host.env) {
-      _hostName = fromRes.host.env;
-    }
-  }
-  return _hostName;
-}
-const getSystemInfo = {
-  returnValue: (fromRes, toRes) => {
-    addSafeAreaInsets(fromRes, toRes);
-    useDeviceId()(fromRes, toRes);
-    populateParameters(fromRes, toRes);
-  }
-};
-const getSystemInfoSync = getSystemInfo;
-const redirectTo = {};
-const previewImage = {
-  args(fromArgs, toArgs) {
-    let currentIndex = parseInt(fromArgs.current);
-    if (isNaN(currentIndex)) {
-      return;
-    }
-    const urls = fromArgs.urls;
-    if (!isArray(urls)) {
-      return;
-    }
-    const len = urls.length;
-    if (!len) {
-      return;
-    }
-    if (currentIndex < 0) {
-      currentIndex = 0;
-    } else if (currentIndex >= len) {
-      currentIndex = len - 1;
-    }
-    if (currentIndex > 0) {
-      toArgs.current = urls[currentIndex];
-      toArgs.urls = urls.filter((item, index2) => index2 < currentIndex ? item !== urls[currentIndex] : true);
-    } else {
-      toArgs.current = urls[0];
-    }
-    return {
-      indicator: false,
-      loop: false
-    };
-  }
-};
-const showActionSheet = {
-  args(fromArgs, toArgs) {
-    toArgs.alertText = fromArgs.title;
-  }
-};
-const getDeviceInfo = {
-  returnValue: (fromRes, toRes) => {
-    const { brand, model } = fromRes;
-    let deviceType = getGetDeviceType(fromRes, model);
-    let deviceBrand = getDeviceBrand(brand);
-    useDeviceId()(fromRes, toRes);
-    toRes = sortObject(extend(toRes, {
-      deviceType,
-      deviceBrand,
-      deviceModel: model
-    }));
-  }
-};
-const getAppBaseInfo = {
-  returnValue: (fromRes, toRes) => {
-    const { version: version2, language, SDKVersion, theme } = fromRes;
-    let _hostName = getHostName(fromRes);
-    let hostLanguage = language.replace(/_/g, "-");
-    toRes = sortObject(extend(toRes, {
-      hostVersion: version2,
-      hostLanguage,
-      hostName: _hostName,
-      hostSDKVersion: SDKVersion,
-      hostTheme: theme,
-      appId: "__UNI__61DDDA4",
-      appName: "his_user_app",
-      appVersion: "1.0.0",
-      appVersionCode: "100",
-      appLanguage: getAppLanguage(hostLanguage)
-    }));
-  }
-};
-const getWindowInfo = {
-  returnValue: (fromRes, toRes) => {
-    addSafeAreaInsets(fromRes, toRes);
-    toRes = sortObject(extend(toRes, {
-      windowTop: 0,
-      windowBottom: 0
-    }));
-  }
-};
-const getAppAuthorizeSetting = {
-  returnValue: function(fromRes, toRes) {
-    const { locationReducedAccuracy } = fromRes;
-    toRes.locationAccuracy = "unsupported";
-    if (locationReducedAccuracy === true) {
-      toRes.locationAccuracy = "reduced";
-    } else if (locationReducedAccuracy === false) {
-      toRes.locationAccuracy = "full";
-    }
-  }
-};
-const mocks$1 = ["__route__", "__wxExparserNodeId__", "__wxWebviewId__"];
-const getProvider = initGetProvider({
-  oauth: ["weixin"],
-  share: ["weixin"],
-  payment: ["wxpay"],
-  push: ["weixin"]
-});
-function initComponentMocks(component) {
-  const res = /* @__PURE__ */ Object.create(null);
-  mocks$1.forEach((name) => {
-    res[name] = component[name];
-  });
-  return res;
-}
-function createSelectorQuery() {
-  const query = wx.createSelectorQuery();
-  const oldIn = query.in;
-  query.in = function newIn(component) {
-    return oldIn.call(this, initComponentMocks(component));
-  };
-  return query;
-}
-var shims = /* @__PURE__ */ Object.freeze({
-  __proto__: null,
-  getProvider,
-  createSelectorQuery
-});
-var protocols = /* @__PURE__ */ Object.freeze({
-  __proto__: null,
-  redirectTo,
-  previewImage,
-  getSystemInfo,
-  getSystemInfoSync,
-  showActionSheet,
-  getDeviceInfo,
-  getAppBaseInfo,
-  getWindowInfo,
-  getAppAuthorizeSetting
-});
-var index = initUni(shims, protocols);
-function warn(msg, ...args) {
-  console.warn(`[Vue warn] ${msg}`, ...args);
-}
-let activeEffectScope;
-class EffectScope {
-  constructor(detached = false) {
-    this.active = true;
-    this.effects = [];
-    this.cleanups = [];
-    if (!detached && activeEffectScope) {
-      this.parent = activeEffectScope;
-      this.index = (activeEffectScope.scopes || (activeEffectScope.scopes = [])).push(this) - 1;
-    }
-  }
-  run(fn) {
-    if (this.active) {
-      const currentEffectScope = activeEffectScope;
-      try {
-        activeEffectScope = this;
-        return fn();
-      } finally {
-        activeEffectScope = currentEffectScope;
-      }
-    } else {
-      warn(`cannot run an inactive effect scope.`);
-    }
-  }
-  on() {
-    activeEffectScope = this;
-  }
-  off() {
-    activeEffectScope = this.parent;
-  }
-  stop(fromParent) {
-    if (this.active) {
-      let i, l;
-      for (i = 0, l = this.effects.length; i < l; i++) {
-        this.effects[i].stop();
-      }
-      for (i = 0, l = this.cleanups.length; i < l; i++) {
-        this.cleanups[i]();
-      }
-      if (this.scopes) {
-        for (i = 0, l = this.scopes.length; i < l; i++) {
-          this.scopes[i].stop(true);
-        }
-      }
-      if (this.parent && !fromParent) {
-        const last = this.parent.scopes.pop();
-        if (last && last !== this) {
-          this.parent.scopes[this.index] = last;
-          last.index = this.index;
-        }
-      }
-      this.active = false;
-    }
-  }
-}
-function recordEffectScope(effect, scope = activeEffectScope) {
-  if (scope && scope.active) {
-    scope.effects.push(effect);
-  }
-}
-const createDep = (effects) => {
-  const dep = new Set(effects);
-  dep.w = 0;
-  dep.n = 0;
-  return dep;
-};
-const wasTracked = (dep) => (dep.w & trackOpBit) > 0;
-const newTracked = (dep) => (dep.n & trackOpBit) > 0;
-const initDepMarkers = ({ deps }) => {
-  if (deps.length) {
-    for (let i = 0; i < deps.length; i++) {
-      deps[i].w |= trackOpBit;
-    }
-  }
-};
-const finalizeDepMarkers = (effect) => {
-  const { deps } = effect;
-  if (deps.length) {
-    let ptr = 0;
-    for (let i = 0; i < deps.length; i++) {
-      const dep = deps[i];
-      if (wasTracked(dep) && !newTracked(dep)) {
-        dep.delete(effect);
-      } else {
-        deps[ptr++] = dep;
-      }
-      dep.w &= ~trackOpBit;
-      dep.n &= ~trackOpBit;
-    }
-    deps.length = ptr;
-  }
-};
-const targetMap = /* @__PURE__ */ new WeakMap();
-let effectTrackDepth = 0;
-let trackOpBit = 1;
-const maxMarkerBits = 30;
-let activeEffect;
-const ITERATE_KEY = Symbol("iterate");
-const MAP_KEY_ITERATE_KEY = Symbol("Map key iterate");
-class ReactiveEffect {
-  constructor(fn, scheduler = null, scope) {
-    this.fn = fn;
-    this.scheduler = scheduler;
-    this.active = true;
-    this.deps = [];
-    this.parent = void 0;
-    recordEffectScope(this, scope);
-  }
-  run() {
-    if (!this.active) {
-      return this.fn();
-    }
-    let parent = activeEffect;
-    let lastShouldTrack = shouldTrack;
-    while (parent) {
-      if (parent === this) {
-        return;
-      }
-      parent = parent.parent;
-    }
-    try {
-      this.parent = activeEffect;
-      activeEffect = this;
-      shouldTrack = true;
-      trackOpBit = 1 << ++effectTrackDepth;
-      if (effectTrackDepth <= maxMarkerBits) {
-        initDepMarkers(this);
-      } else {
-        cleanupEffect(this);
-      }
-      return this.fn();
-    } finally {
-      if (effectTrackDepth <= maxMarkerBits) {
-        finalizeDepMarkers(this);
-      }
-      trackOpBit = 1 << --effectTrackDepth;
-      activeEffect = this.parent;
-      shouldTrack = lastShouldTrack;
-      this.parent = void 0;
-      if (this.deferStop) {
-        this.stop();
-      }
-    }
-  }
-  stop() {
-    if (activeEffect === this) {
-      this.deferStop = true;
-    } else if (this.active) {
-      cleanupEffect(this);
-      if (this.onStop) {
-        this.onStop();
-      }
-      this.active = false;
-    }
-  }
-}
-function cleanupEffect(effect) {
-  const { deps } = effect;
-  if (deps.length) {
-    for (let i = 0; i < deps.length; i++) {
-      deps[i].delete(effect);
-    }
-    deps.length = 0;
-  }
-}
-let shouldTrack = true;
-const trackStack = [];
-function pauseTracking() {
-  trackStack.push(shouldTrack);
-  shouldTrack = false;
-}
-function resetTracking() {
-  const last = trackStack.pop();
-  shouldTrack = last === void 0 ? true : last;
-}
-function track(target, type, key) {
-  if (shouldTrack && activeEffect) {
-    let depsMap = targetMap.get(target);
-    if (!depsMap) {
-      targetMap.set(target, depsMap = /* @__PURE__ */ new Map());
-    }
-    let dep = depsMap.get(key);
-    if (!dep) {
-      depsMap.set(key, dep = createDep());
-    }
-    const eventInfo = { effect: activeEffect, target, type, key };
-    trackEffects(dep, eventInfo);
-  }
-}
-function trackEffects(dep, debuggerEventExtraInfo) {
-  let shouldTrack2 = false;
-  if (effectTrackDepth <= maxMarkerBits) {
-    if (!newTracked(dep)) {
-      dep.n |= trackOpBit;
-      shouldTrack2 = !wasTracked(dep);
-    }
-  } else {
-    shouldTrack2 = !dep.has(activeEffect);
-  }
-  if (shouldTrack2) {
-    dep.add(activeEffect);
-    activeEffect.deps.push(dep);
-    if (activeEffect.onTrack) {
-      activeEffect.onTrack(Object.assign({ effect: activeEffect }, debuggerEventExtraInfo));
-    }
-  }
-}
-function trigger(target, type, key, newValue, oldValue, oldTarget) {
-  const depsMap = targetMap.get(target);
-  if (!depsMap) {
-    return;
-  }
-  let deps = [];
-  if (type === "clear") {
-    deps = [...depsMap.values()];
-  } else if (key === "length" && isArray(target)) {
-    depsMap.forEach((dep, key2) => {
-      if (key2 === "length" || key2 >= newValue) {
-        deps.push(dep);
-      }
-    });
-  } else {
-    if (key !== void 0) {
-      deps.push(depsMap.get(key));
-    }
-    switch (type) {
-      case "add":
-        if (!isArray(target)) {
-          deps.push(depsMap.get(ITERATE_KEY));
-          if (isMap(target)) {
-            deps.push(depsMap.get(MAP_KEY_ITERATE_KEY));
-          }
-        } else if (isIntegerKey(key)) {
-          deps.push(depsMap.get("length"));
-        }
-        break;
-      case "delete":
-        if (!isArray(target)) {
-          deps.push(depsMap.get(ITERATE_KEY));
-          if (isMap(target)) {
-            deps.push(depsMap.get(MAP_KEY_ITERATE_KEY));
-          }
-        }
-        break;
-      case "set":
-        if (isMap(target)) {
-          deps.push(depsMap.get(ITERATE_KEY));
-        }
-        break;
-    }
-  }
-  const eventInfo = { target, type, key, newValue, oldValue, oldTarget };
-  if (deps.length === 1) {
-    if (deps[0]) {
-      {
-        triggerEffects(deps[0], eventInfo);
-      }
-    }
-  } else {
-    const effects = [];
-    for (const dep of deps) {
-      if (dep) {
-        effects.push(...dep);
-      }
-    }
-    {
-      triggerEffects(createDep(effects), eventInfo);
-    }
-  }
-}
-function triggerEffects(dep, debuggerEventExtraInfo) {
-  const effects = isArray(dep) ? dep : [...dep];
-  for (const effect of effects) {
-    if (effect.computed) {
-      triggerEffect(effect, debuggerEventExtraInfo);
-    }
-  }
-  for (const effect of effects) {
-    if (!effect.computed) {
-      triggerEffect(effect, debuggerEventExtraInfo);
-    }
-  }
-}
-function triggerEffect(effect, debuggerEventExtraInfo) {
-  if (effect !== activeEffect || effect.allowRecurse) {
-    if (effect.onTrigger) {
-      effect.onTrigger(extend({ effect }, debuggerEventExtraInfo));
-    }
-    if (effect.scheduler) {
-      effect.scheduler();
-    } else {
-      effect.run();
-    }
-  }
-}
-const isNonTrackableKeys = /* @__PURE__ */ makeMap(`__proto__,__v_isRef,__isVue`);
-const builtInSymbols = new Set(/* @__PURE__ */ Object.getOwnPropertyNames(Symbol).filter((key) => key !== "arguments" && key !== "caller").map((key) => Symbol[key]).filter(isSymbol));
-const get = /* @__PURE__ */ createGetter();
-const shallowGet = /* @__PURE__ */ createGetter(false, true);
-const readonlyGet = /* @__PURE__ */ createGetter(true);
-const shallowReadonlyGet = /* @__PURE__ */ createGetter(true, true);
-const arrayInstrumentations = /* @__PURE__ */ createArrayInstrumentations();
-function createArrayInstrumentations() {
-  const instrumentations = {};
-  ["includes", "indexOf", "lastIndexOf"].forEach((key) => {
-    instrumentations[key] = function(...args) {
-      const arr = toRaw(this);
-      for (let i = 0, l = this.length; i < l; i++) {
-        track(arr, "get", i + "");
-      }
-      const res = arr[key](...args);
-      if (res === -1 || res === false) {
-        return arr[key](...args.map(toRaw));
-      } else {
-        return res;
-      }
-    };
-  });
-  ["push", "pop", "shift", "unshift", "splice"].forEach((key) => {
-    instrumentations[key] = function(...args) {
-      pauseTracking();
-      const res = toRaw(this)[key].apply(this, args);
-      resetTracking();
-      return res;
-    };
-  });
-  return instrumentations;
-}
-function createGetter(isReadonly2 = false, shallow = false) {
-  return function get3(target, key, receiver) {
-    if (key === "__v_isReactive") {
-      return !isReadonly2;
-    } else if (key === "__v_isReadonly") {
-      return isReadonly2;
-    } else if (key === "__v_isShallow") {
-      return shallow;
-    } else if (key === "__v_raw" && receiver === (isReadonly2 ? shallow ? shallowReadonlyMap : readonlyMap : shallow ? shallowReactiveMap : reactiveMap).get(target)) {
-      return target;
-    }
-    const targetIsArray = isArray(target);
-    if (!isReadonly2 && targetIsArray && hasOwn(arrayInstrumentations, key)) {
-      return Reflect.get(arrayInstrumentations, key, receiver);
-    }
-    const res = Reflect.get(target, key, receiver);
-    if (isSymbol(key) ? builtInSymbols.has(key) : isNonTrackableKeys(key)) {
-      return res;
-    }
-    if (!isReadonly2) {
-      track(target, "get", key);
-    }
-    if (shallow) {
-      return res;
-    }
-    if (isRef(res)) {
-      return targetIsArray && isIntegerKey(key) ? res : res.value;
-    }
-    if (isObject$1(res)) {
-      return isReadonly2 ? readonly(res) : reactive(res);
-    }
-    return res;
-  };
-}
-const set$1 = /* @__PURE__ */ createSetter();
-const shallowSet = /* @__PURE__ */ createSetter(true);
-function createSetter(shallow = false) {
-  return function set2(target, key, value, receiver) {
-    let oldValue = target[key];
-    if (isReadonly(oldValue) && isRef(oldValue) && !isRef(value)) {
-      return false;
-    }
-    if (!shallow && !isReadonly(value)) {
-      if (!isShallow(value)) {
-        value = toRaw(value);
-        oldValue = toRaw(oldValue);
-      }
-      if (!isArray(target) && isRef(oldValue) && !isRef(value)) {
-        oldValue.value = value;
-        return true;
-      }
-    }
-    const hadKey = isArray(target) && isIntegerKey(key) ? Number(key) < target.length : hasOwn(target, key);
-    const result = Reflect.set(target, key, value, receiver);
-    if (target === toRaw(receiver)) {
-      if (!hadKey) {
-        trigger(target, "add", key, value);
-      } else if (hasChanged(value, oldValue)) {
-        trigger(target, "set", key, value, oldValue);
-      }
-    }
-    return result;
-  };
-}
-function deleteProperty(target, key) {
-  const hadKey = hasOwn(target, key);
-  const oldValue = target[key];
-  const result = Reflect.deleteProperty(target, key);
-  if (result && hadKey) {
-    trigger(target, "delete", key, void 0, oldValue);
-  }
-  return result;
-}
-function has(target, key) {
-  const result = Reflect.has(target, key);
-  if (!isSymbol(key) || !builtInSymbols.has(key)) {
-    track(target, "has", key);
-  }
-  return result;
-}
-function ownKeys(target) {
-  track(target, "iterate", isArray(target) ? "length" : ITERATE_KEY);
-  return Reflect.ownKeys(target);
-}
-const mutableHandlers = {
-  get,
-  set: set$1,
-  deleteProperty,
-  has,
-  ownKeys
-};
-const readonlyHandlers = {
-  get: readonlyGet,
-  set(target, key) {
-    {
-      warn(`Set operation on key "${String(key)}" failed: target is readonly.`, target);
-    }
-    return true;
-  },
-  deleteProperty(target, key) {
-    {
-      warn(`Delete operation on key "${String(key)}" failed: target is readonly.`, target);
-    }
-    return true;
-  }
-};
-const shallowReactiveHandlers = /* @__PURE__ */ extend({}, mutableHandlers, {
-  get: shallowGet,
-  set: shallowSet
-});
-const shallowReadonlyHandlers = /* @__PURE__ */ extend({}, readonlyHandlers, {
-  get: shallowReadonlyGet
-});
-const toShallow = (value) => value;
-const getProto = (v) => Reflect.getPrototypeOf(v);
-function get$1(target, key, isReadonly2 = false, isShallow2 = false) {
-  target = target["__v_raw"];
-  const rawTarget = toRaw(target);
-  const rawKey = toRaw(key);
-  if (!isReadonly2) {
-    if (key !== rawKey) {
-      track(rawTarget, "get", key);
-    }
-    track(rawTarget, "get", rawKey);
-  }
-  const { has: has2 } = getProto(rawTarget);
-  const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;
-  if (has2.call(rawTarget, key)) {
-    return wrap(target.get(key));
-  } else if (has2.call(rawTarget, rawKey)) {
-    return wrap(target.get(rawKey));
-  } else if (target !== rawTarget) {
-    target.get(key);
-  }
-}
-function has$1(key, isReadonly2 = false) {
-  const target = this["__v_raw"];
-  const rawTarget = toRaw(target);
-  const rawKey = toRaw(key);
-  if (!isReadonly2) {
-    if (key !== rawKey) {
-      track(rawTarget, "has", key);
-    }
-    track(rawTarget, "has", rawKey);
-  }
-  return key === rawKey ? target.has(key) : target.has(key) || target.has(rawKey);
-}
-function size(target, isReadonly2 = false) {
-  target = target["__v_raw"];
-  !isReadonly2 && track(toRaw(target), "iterate", ITERATE_KEY);
-  return Reflect.get(target, "size", target);
-}
-function add(value) {
-  value = toRaw(value);
-  const target = toRaw(this);
-  const proto = getProto(target);
-  const hadKey = proto.has.call(target, value);
-  if (!hadKey) {
-    target.add(value);
-    trigger(target, "add", value, value);
-  }
-  return this;
-}
-function set$1$1(key, value) {
-  value = toRaw(value);
-  const target = toRaw(this);
-  const { has: has2, get: get3 } = getProto(target);
-  let hadKey = has2.call(target, key);
-  if (!hadKey) {
-    key = toRaw(key);
-    hadKey = has2.call(target, key);
-  } else {
-    checkIdentityKeys(target, has2, key);
-  }
-  const oldValue = get3.call(target, key);
-  target.set(key, value);
-  if (!hadKey) {
-    trigger(target, "add", key, value);
-  } else if (hasChanged(value, oldValue)) {
-    trigger(target, "set", key, value, oldValue);
-  }
-  return this;
-}
-function deleteEntry(key) {
-  const target = toRaw(this);
-  const { has: has2, get: get3 } = getProto(target);
-  let hadKey = has2.call(target, key);
-  if (!hadKey) {
-    key = toRaw(key);
-    hadKey = has2.call(target, key);
-  } else {
-    checkIdentityKeys(target, has2, key);
-  }
-  const oldValue = get3 ? get3.call(target, key) : void 0;
-  const result = target.delete(key);
-  if (hadKey) {
-    trigger(target, "delete", key, void 0, oldValue);
-  }
-  return result;
-}
-function clear() {
-  const target = toRaw(this);
-  const hadItems = target.size !== 0;
-  const oldTarget = isMap(target) ? new Map(target) : new Set(target);
-  const result = target.clear();
-  if (hadItems) {
-    trigger(target, "clear", void 0, void 0, oldTarget);
-  }
-  return result;
-}
-function createForEach(isReadonly2, isShallow2) {
-  return function forEach(callback, thisArg) {
-    const observed = this;
-    const target = observed["__v_raw"];
-    const rawTarget = toRaw(target);
-    const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;
-    !isReadonly2 && track(rawTarget, "iterate", ITERATE_KEY);
-    return target.forEach((value, key) => {
-      return callback.call(thisArg, wrap(value), wrap(key), observed);
-    });
-  };
-}
-function createIterableMethod(method, isReadonly2, isShallow2) {
-  return function(...args) {
-    const target = this["__v_raw"];
-    const rawTarget = toRaw(target);
-    const targetIsMap = isMap(rawTarget);
-    const isPair = method === "entries" || method === Symbol.iterator && targetIsMap;
-    const isKeyOnly = method === "keys" && targetIsMap;
-    const innerIterator = target[method](...args);
-    const wrap = isShallow2 ? toShallow : isReadonly2 ? toReadonly : toReactive;
-    !isReadonly2 && track(rawTarget, "iterate", isKeyOnly ? MAP_KEY_ITERATE_KEY : ITERATE_KEY);
-    return {
-      next() {
-        const { value, done } = innerIterator.next();
-        return done ? { value, done } : {
-          value: isPair ? [wrap(value[0]), wrap(value[1])] : wrap(value),
-          done
-        };
-      },
-      [Symbol.iterator]() {
-        return this;
-      }
-    };
-  };
-}
-function createReadonlyMethod(type) {
-  return function(...args) {
-    {
-      const key = args[0] ? `on key "${args[0]}" ` : ``;
-      console.warn(`${capitalize(type)} operation ${key}failed: target is readonly.`, toRaw(this));
-    }
-    return type === "delete" ? false : this;
-  };
-}
-function createInstrumentations() {
-  const mutableInstrumentations2 = {
-    get(key) {
-      return get$1(this, key);
-    },
-    get size() {
-      return size(this);
-    },
-    has: has$1,
-    add,
-    set: set$1$1,
-    delete: deleteEntry,
-    clear,
-    forEach: createForEach(false, false)
-  };
-  const shallowInstrumentations2 = {
-    get(key) {
-      return get$1(this, key, false, true);
-    },
-    get size() {
-      return size(this);
-    },
-    has: has$1,
-    add,
-    set: set$1$1,
-    delete: deleteEntry,
-    clear,
-    forEach: createForEach(false, true)
-  };
-  const readonlyInstrumentations2 = {
-    get(key) {
-      return get$1(this, key, true);
-    },
-    get size() {
-      return size(this, true);
-    },
-    has(key) {
-      return has$1.call(this, key, true);
-    },
-    add: createReadonlyMethod("add"),
-    set: createReadonlyMethod("set"),
-    delete: createReadonlyMethod("delete"),
-    clear: createReadonlyMethod("clear"),
-    forEach: createForEach(true, false)
-  };
-  const shallowReadonlyInstrumentations2 = {
-    get(key) {
-      return get$1(this, key, true, true);
-    },
-    get size() {
-      return size(this, true);
-    },
-    has(key) {
-      return has$1.call(this, key, true);
-    },
-    add: createReadonlyMethod("add"),
-    set: createReadonlyMethod("set"),
-    delete: createReadonlyMethod("delete"),
-    clear: createReadonlyMethod("clear"),
-    forEach: createForEach(true, true)
-  };
-  const iteratorMethods = ["keys", "values", "entries", Symbol.iterator];
-  iteratorMethods.forEach((method) => {
-    mutableInstrumentations2[method] = createIterableMethod(method, false, false);
-    readonlyInstrumentations2[method] = createIterableMethod(method, true, false);
-    shallowInstrumentations2[method] = createIterableMethod(method, false, true);
-    shallowReadonlyInstrumentations2[method] = createIterableMethod(method, true, true);
-  });
-  return [
-    mutableInstrumentations2,
-    readonlyInstrumentations2,
-    shallowInstrumentations2,
-    shallowReadonlyInstrumentations2
-  ];
-}
-const [mutableInstrumentations, readonlyInstrumentations, shallowInstrumentations, shallowReadonlyInstrumentations] = /* @__PURE__ */ createInstrumentations();
-function createInstrumentationGetter(isReadonly2, shallow) {
-  const instrumentations = shallow ? isReadonly2 ? shallowReadonlyInstrumentations : shallowInstrumentations : isReadonly2 ? readonlyInstrumentations : mutableInstrumentations;
-  return (target, key, receiver) => {
-    if (key === "__v_isReactive") {
-      return !isReadonly2;
-    } else if (key === "__v_isReadonly") {
-      return isReadonly2;
-    } else if (key === "__v_raw") {
-      return target;
-    }
-    return Reflect.get(hasOwn(instrumentations, key) && key in target ? instrumentations : target, key, receiver);
-  };
-}
-const mutableCollectionHandlers = {
-  get: /* @__PURE__ */ createInstrumentationGetter(false, false)
-};
-const shallowCollectionHandlers = {
-  get: /* @__PURE__ */ createInstrumentationGetter(false, true)
-};
-const readonlyCollectionHandlers = {
-  get: /* @__PURE__ */ createInstrumentationGetter(true, false)
-};
-const shallowReadonlyCollectionHandlers = {
-  get: /* @__PURE__ */ createInstrumentationGetter(true, true)
-};
-function checkIdentityKeys(target, has2, key) {
-  const rawKey = toRaw(key);
-  if (rawKey !== key && has2.call(target, rawKey)) {
-    const type = toRawType(target);
-    console.warn(`Reactive ${type} contains both the raw and reactive versions of the same object${type === `Map` ? ` as keys` : ``}, which can lead to inconsistencies. Avoid differentiating between the raw and reactive versions of an object and only use the reactive version if possible.`);
-  }
-}
-const reactiveMap = /* @__PURE__ */ new WeakMap();
-const shallowReactiveMap = /* @__PURE__ */ new WeakMap();
-const readonlyMap = /* @__PURE__ */ new WeakMap();
-const shallowReadonlyMap = /* @__PURE__ */ new WeakMap();
-function targetTypeMap(rawType) {
-  switch (rawType) {
-    case "Object":
-    case "Array":
-      return 1;
-    case "Map":
-    case "Set":
-    case "WeakMap":
-    case "WeakSet":
-      return 2;
-    default:
-      return 0;
-  }
-}
-function getTargetType(value) {
-  return value["__v_skip"] || !Object.isExtensible(value) ? 0 : targetTypeMap(toRawType(value));
-}
-function reactive(target) {
-  if (isReadonly(target)) {
-    return target;
-  }
-  return createReactiveObject(target, false, mutableHandlers, mutableCollectionHandlers, reactiveMap);
-}
-function shallowReactive(target) {
-  return createReactiveObject(target, false, shallowReactiveHandlers, shallowCollectionHandlers, shallowReactiveMap);
-}
-function readonly(target) {
-  return createReactiveObject(target, true, readonlyHandlers, readonlyCollectionHandlers, readonlyMap);
-}
-function shallowReadonly(target) {
-  return createReactiveObject(target, true, shallowReadonlyHandlers, shallowReadonlyCollectionHandlers, shallowReadonlyMap);
-}
-function createReactiveObject(target, isReadonly2, baseHandlers, collectionHandlers, proxyMap) {
-  if (!isObject$1(target)) {
-    {
-      console.warn(`value cannot be made reactive: ${String(target)}`);
-    }
-    return target;
-  }
-  if (target["__v_raw"] && !(isReadonly2 && target["__v_isReactive"])) {
-    return target;
-  }
-  const existingProxy = proxyMap.get(target);
-  if (existingProxy) {
-    return existingProxy;
-  }
-  const targetType = getTargetType(target);
-  if (targetType === 0) {
-    return target;
-  }
-  const proxy = new Proxy(target, targetType === 2 ? collectionHandlers : baseHandlers);
-  proxyMap.set(target, proxy);
-  return proxy;
-}
-function isReactive(value) {
-  if (isReadonly(value)) {
-    return isReactive(value["__v_raw"]);
-  }
-  return !!(value && value["__v_isReactive"]);
-}
-function isReadonly(value) {
-  return !!(value && value["__v_isReadonly"]);
-}
-function isShallow(value) {
-  return !!(value && value["__v_isShallow"]);
-}
-function isProxy(value) {
-  return isReactive(value) || isReadonly(value);
-}
-function toRaw(observed) {
-  const raw = observed && observed["__v_raw"];
-  return raw ? toRaw(raw) : observed;
-}
-function markRaw(value) {
-  def(value, "__v_skip", true);
-  return value;
-}
-const toReactive = (value) => isObject$1(value) ? reactive(value) : value;
-const toReadonly = (value) => isObject$1(value) ? readonly(value) : value;
-function trackRefValue(ref2) {
-  if (shouldTrack && activeEffect) {
-    ref2 = toRaw(ref2);
-    {
-      trackEffects(ref2.dep || (ref2.dep = createDep()), {
-        target: ref2,
-        type: "get",
-        key: "value"
-      });
-    }
-  }
-}
-function triggerRefValue(ref2, newVal) {
-  ref2 = toRaw(ref2);
-  if (ref2.dep) {
-    {
-      triggerEffects(ref2.dep, {
-        target: ref2,
-        type: "set",
-        key: "value",
-        newValue: newVal
-      });
-    }
-  }
-}
-function isRef(r) {
-  return !!(r && r.__v_isRef === true);
-}
-function ref(value) {
-  return createRef(value, false);
-}
-function shallowRef(value) {
-  return createRef(value, true);
-}
-function createRef(rawValue, shallow) {
-  if (isRef(rawValue)) {
-    return rawValue;
-  }
-  return new RefImpl(rawValue, shallow);
-}
-class RefImpl {
-  constructor(value, __v_isShallow) {
-    this.__v_isShallow = __v_isShallow;
-    this.dep = void 0;
-    this.__v_isRef = true;
-    this._rawValue = __v_isShallow ? value : toRaw(value);
-    this._value = __v_isShallow ? value : toReactive(value);
-  }
-  get value() {
-    trackRefValue(this);
-    return this._value;
-  }
-  set value(newVal) {
-    newVal = this.__v_isShallow ? newVal : toRaw(newVal);
-    if (hasChanged(newVal, this._rawValue)) {
-      this._rawValue = newVal;
-      this._value = this.__v_isShallow ? newVal : toReactive(newVal);
-      triggerRefValue(this, newVal);
-    }
-  }
-}
-function unref(ref2) {
-  return isRef(ref2) ? ref2.value : ref2;
-}
-const shallowUnwrapHandlers = {
-  get: (target, key, receiver) => unref(Reflect.get(target, key, receiver)),
-  set: (target, key, value, receiver) => {
-    const oldValue = target[key];
-    if (isRef(oldValue) && !isRef(value)) {
-      oldValue.value = value;
-      return true;
-    } else {
-      return Reflect.set(target, key, value, receiver);
-    }
-  }
-};
-function proxyRefs(objectWithRefs) {
-  return isReactive(objectWithRefs) ? objectWithRefs : new Proxy(objectWithRefs, shallowUnwrapHandlers);
-}
-function toRefs(object) {
-  if (!isProxy(object)) {
-    console.warn(`toRefs() expects a reactive object but received a plain one.`);
-  }
-  const ret = isArray(object) ? new Array(object.length) : {};
-  for (const key in object) {
-    ret[key] = toRef(object, key);
-  }
-  return ret;
-}
-class ObjectRefImpl {
-  constructor(_object, _key, _defaultValue) {
-    this._object = _object;
-    this._key = _key;
-    this._defaultValue = _defaultValue;
-    this.__v_isRef = true;
-  }
-  get value() {
-    const val = this._object[this._key];
-    return val === void 0 ? this._defaultValue : val;
-  }
-  set value(newVal) {
-    this._object[this._key] = newVal;
-  }
-}
-function toRef(object, key, defaultValue) {
-  const val = object[key];
-  return isRef(val) ? val : new ObjectRefImpl(object, key, defaultValue);
-}
-class ComputedRefImpl {
-  constructor(getter, _setter, isReadonly2, isSSR) {
-    this._setter = _setter;
-    this.dep = void 0;
-    this.__v_isRef = true;
-    this._dirty = true;
-    this.effect = new ReactiveEffect(getter, () => {
-      if (!this._dirty) {
-        this._dirty = true;
-        triggerRefValue(this);
-      }
-    });
-    this.effect.computed = this;
-    this.effect.active = this._cacheable = !isSSR;
-    this["__v_isReadonly"] = isReadonly2;
-  }
-  get value() {
-    const self2 = toRaw(this);
-    trackRefValue(self2);
-    if (self2._dirty || !self2._cacheable) {
-      self2._dirty = false;
-      self2._value = self2.effect.run();
-    }
-    return self2._value;
-  }
-  set value(newValue) {
-    this._setter(newValue);
-  }
-}
-function computed(getterOrOptions, debugOptions, isSSR = false) {
-  let getter;
-  let setter;
-  const onlyGetter = isFunction(getterOrOptions);
-  if (onlyGetter) {
-    getter = getterOrOptions;
-    setter = () => {
-      console.warn("Write operation failed: computed value is readonly");
-    };
-  } else {
-    getter = getterOrOptions.get;
-    setter = getterOrOptions.set;
-  }
-  const cRef = new ComputedRefImpl(getter, setter, onlyGetter || !setter, isSSR);
-  if (debugOptions && !isSSR) {
-    cRef.effect.onTrack = debugOptions.onTrack;
-    cRef.effect.onTrigger = debugOptions.onTrigger;
-  }
-  return cRef;
-}
-const stack = [];
-function pushWarningContext(vnode) {
-  stack.push(vnode);
-}
-function popWarningContext() {
-  stack.pop();
-}
-function warn$1(msg, ...args) {
-  pauseTracking();
-  const instance = stack.length ? stack[stack.length - 1].component : null;
-  const appWarnHandler = instance && instance.appContext.config.warnHandler;
-  const trace = getComponentTrace();
-  if (appWarnHandler) {
-    callWithErrorHandling(appWarnHandler, instance, 11, [
-      msg + args.join(""),
-      instance && instance.proxy,
-      trace.map(({ vnode }) => `at <${formatComponentName(instance, vnode.type)}>`).join("\n"),
-      trace
-    ]);
-  } else {
-    const warnArgs = [`[Vue warn]: ${msg}`, ...args];
-    if (trace.length && true) {
-      warnArgs.push(`
-`, ...formatTrace(trace));
-    }
-    console.warn(...warnArgs);
-  }
-  resetTracking();
-}
-function getComponentTrace() {
-  let currentVNode = stack[stack.length - 1];
-  if (!currentVNode) {
-    return [];
-  }
-  const normalizedStack = [];
-  while (currentVNode) {
-    const last = normalizedStack[0];
-    if (last && last.vnode === currentVNode) {
-      last.recurseCount++;
-    } else {
-      normalizedStack.push({
-        vnode: currentVNode,
-        recurseCount: 0
-      });
-    }
-    const parentInstance = currentVNode.component && currentVNode.component.parent;
-    currentVNode = parentInstance && parentInstance.vnode;
-  }
-  return normalizedStack;
-}
-function formatTrace(trace) {
-  const logs = [];
-  trace.forEach((entry, i) => {
-    logs.push(...i === 0 ? [] : [`
-`], ...formatTraceEntry(entry));
-  });
-  return logs;
-}
-function formatTraceEntry({ vnode, recurseCount }) {
-  const postfix = recurseCount > 0 ? `... (${recurseCount} recursive calls)` : ``;
-  const isRoot = vnode.component ? vnode.component.parent == null : false;
-  const open = ` at <${formatComponentName(vnode.component, vnode.type, isRoot)}`;
-  const close = `>` + postfix;
-  return vnode.props ? [open, ...formatProps(vnode.props), close] : [open + close];
-}
-function formatProps(props) {
-  const res = [];
-  const keys = Object.keys(props);
-  keys.slice(0, 3).forEach((key) => {
-    res.push(...formatProp(key, props[key]));
-  });
-  if (keys.length > 3) {
-    res.push(` ...`);
-  }
-  return res;
-}
-function formatProp(key, value, raw) {
-  if (isString(value)) {
-    value = JSON.stringify(value);
-    return raw ? value : [`${key}=${value}`];
-  } else if (typeof value === "number" || typeof value === "boolean" || value == null) {
-    return raw ? value : [`${key}=${value}`];
-  } else if (isRef(value)) {
-    value = formatProp(key, toRaw(value.value), true);
-    return raw ? value : [`${key}=Ref<`, value, `>`];
-  } else if (isFunction(value)) {
-    return [`${key}=fn${value.name ? `<${value.name}>` : ``}`];
-  } else {
-    value = toRaw(value);
-    return raw ? value : [`${key}=`, value];
-  }
-}
-const ErrorTypeStrings = {
-  ["sp"]: "serverPrefetch hook",
-  ["bc"]: "beforeCreate hook",
-  ["c"]: "created hook",
-  ["bm"]: "beforeMount hook",
-  ["m"]: "mounted hook",
-  ["bu"]: "beforeUpdate hook",
-  ["u"]: "updated",
-  ["bum"]: "beforeUnmount hook",
-  ["um"]: "unmounted hook",
-  ["a"]: "activated hook",
-  ["da"]: "deactivated hook",
-  ["ec"]: "errorCaptured hook",
-  ["rtc"]: "renderTracked hook",
-  ["rtg"]: "renderTriggered hook",
-  [0]: "setup function",
-  [1]: "render function",
-  [2]: "watcher getter",
-  [3]: "watcher callback",
-  [4]: "watcher cleanup function",
-  [5]: "native event handler",
-  [6]: "component event handler",
-  [7]: "vnode hook",
-  [8]: "directive hook",
-  [9]: "transition hook",
-  [10]: "app errorHandler",
-  [11]: "app warnHandler",
-  [12]: "ref function",
-  [13]: "async component loader",
-  [14]: "scheduler flush. This is likely a Vue internals bug. Please open an issue at https://new-issue.vuejs.org/?repo=vuejs/core"
-};
-function callWithErrorHandling(fn, instance, type, args) {
-  let res;
-  try {
-    res = args ? fn(...args) : fn();
-  } catch (err) {
-    handleError(err, instance, type);
-  }
-  return res;
-}
-function callWithAsyncErrorHandling(fn, instance, type, args) {
-  if (isFunction(fn)) {
-    const res = callWithErrorHandling(fn, instance, type, args);
-    if (res && isPromise$1(res)) {
-      res.catch((err) => {
-        handleError(err, instance, type);
-      });
-    }
-    return res;
-  }
-  const values = [];
-  for (let i = 0; i < fn.length; i++) {
-    values.push(callWithAsyncErrorHandling(fn[i], instance, type, args));
-  }
-  return values;
-}
-function handleError(err, instance, type, throwInDev = true) {
-  const contextVNode = instance ? instance.vnode : null;
-  if (instance) {
-    let cur = instance.parent;
-    const exposedInstance = instance.proxy;
-    const errorInfo = ErrorTypeStrings[type] || type;
-    while (cur) {
-      const errorCapturedHooks = cur.ec;
-      if (errorCapturedHooks) {
-        for (let i = 0; i < errorCapturedHooks.length; i++) {
-          if (errorCapturedHooks[i](err, exposedInstance, errorInfo) === false) {
-            return;
-          }
-        }
-      }
-      cur = cur.parent;
-    }
-    const appErrorHandler = instance.appContext.config.errorHandler;
-    if (appErrorHandler) {
-      callWithErrorHandling(appErrorHandler, null, 10, [err, exposedInstance, errorInfo]);
-      return;
-    }
-  }
-  logError(err, type, contextVNode, throwInDev);
-}
-function logError(err, type, contextVNode, throwInDev = true) {
-  {
-    const info = ErrorTypeStrings[type] || type;
-    if (contextVNode) {
-      pushWarningContext(contextVNode);
-    }
-    warn$1(`Unhandled error${info ? ` during execution of ${info}` : ``}`);
-    if (contextVNode) {
-      popWarningContext();
-    }
-    if (throwInDev) {
-      console.error(err);
-    } else {
-      console.error(err);
-    }
-  }
-}
-let isFlushing = false;
-let isFlushPending = false;
-const queue = [];
-let flushIndex = 0;
-const pendingPreFlushCbs = [];
-let activePreFlushCbs = null;
-let preFlushIndex = 0;
-const pendingPostFlushCbs = [];
-let activePostFlushCbs = null;
-let postFlushIndex = 0;
-const resolvedPromise = /* @__PURE__ */ Promise.resolve();
-let currentFlushPromise = null;
-let currentPreFlushParentJob = null;
-const RECURSION_LIMIT = 100;
-function nextTick(fn) {
-  const p2 = currentFlushPromise || resolvedPromise;
-  return fn ? p2.then(this ? fn.bind(this) : fn) : p2;
-}
-function findInsertionIndex(id) {
-  let start = flushIndex + 1;
-  let end = queue.length;
-  while (start < end) {
-    const middle = start + end >>> 1;
-    const middleJobId = getId(queue[middle]);
-    middleJobId < id ? start = middle + 1 : end = middle;
-  }
-  return start;
-}
-function queueJob(job) {
-  if ((!queue.length || !queue.includes(job, isFlushing && job.allowRecurse ? flushIndex + 1 : flushIndex)) && job !== currentPreFlushParentJob) {
-    if (job.id == null) {
-      queue.push(job);
-    } else {
-      queue.splice(findInsertionIndex(job.id), 0, job);
-    }
-    queueFlush();
-  }
-}
-function queueFlush() {
-  if (!isFlushing && !isFlushPending) {
-    isFlushPending = true;
-    currentFlushPromise = resolvedPromise.then(flushJobs);
-  }
-}
-function hasQueueJob(job) {
-  return queue.indexOf(job) > -1;
-}
-function invalidateJob(job) {
-  const i = queue.indexOf(job);
-  if (i > flushIndex) {
-    queue.splice(i, 1);
-  }
-}
-function queueCb(cb, activeQueue, pendingQueue, index2) {
-  if (!isArray(cb)) {
-    if (!activeQueue || !activeQueue.includes(cb, cb.allowRecurse ? index2 + 1 : index2)) {
-      pendingQueue.push(cb);
-    }
-  } else {
-    pendingQueue.push(...cb);
-  }
-  queueFlush();
-}
-function queuePreFlushCb(cb) {
-  queueCb(cb, activePreFlushCbs, pendingPreFlushCbs, preFlushIndex);
-}
-function queuePostFlushCb(cb) {
-  queueCb(cb, activePostFlushCbs, pendingPostFlushCbs, postFlushIndex);
-}
-function flushPreFlushCbs(seen, parentJob = null) {
-  if (pendingPreFlushCbs.length) {
-    currentPreFlushParentJob = parentJob;
-    activePreFlushCbs = [...new Set(pendingPreFlushCbs)];
-    pendingPreFlushCbs.length = 0;
-    {
-      seen = seen || /* @__PURE__ */ new Map();
-    }
-    for (preFlushIndex = 0; preFlushIndex < activePreFlushCbs.length; preFlushIndex++) {
-      if (checkRecursiveUpdates(seen, activePreFlushCbs[preFlushIndex])) {
-        continue;
-      }
-      activePreFlushCbs[preFlushIndex]();
-    }
-    activePreFlushCbs = null;
-    preFlushIndex = 0;
-    currentPreFlushParentJob = null;
-    flushPreFlushCbs(seen, parentJob);
-  }
-}
-function flushPostFlushCbs(seen) {
-  flushPreFlushCbs();
-  if (pendingPostFlushCbs.length) {
-    const deduped = [...new Set(pendingPostFlushCbs)];
-    pendingPostFlushCbs.length = 0;
-    if (activePostFlushCbs) {
-      activePostFlushCbs.push(...deduped);
-      return;
-    }
-    activePostFlushCbs = deduped;
-    {
-      seen = seen || /* @__PURE__ */ new Map();
-    }
-    activePostFlushCbs.sort((a, b) => getId(a) - getId(b));
-    for (postFlushIndex = 0; postFlushIndex < activePostFlushCbs.length; postFlushIndex++) {
-      if (checkRecursiveUpdates(seen, activePostFlushCbs[postFlushIndex])) {
-        continue;
-      }
-      activePostFlushCbs[postFlushIndex]();
-    }
-    activePostFlushCbs = null;
-    postFlushIndex = 0;
-  }
-}
-const getId = (job) => job.id == null ? Infinity : job.id;
-function flushJobs(seen) {
-  isFlushPending = false;
-  isFlushing = true;
-  {
-    seen = seen || /* @__PURE__ */ new Map();
-  }
-  flushPreFlushCbs(seen);
-  queue.sort((a, b) => getId(a) - getId(b));
-  const check = (job) => checkRecursiveUpdates(seen, job);
-  try {
-    for (flushIndex = 0; flushIndex < queue.length; flushIndex++) {
-      const job = queue[flushIndex];
-      if (job && job.active !== false) {
-        if (check(job)) {
-          continue;
-        }
-        callWithErrorHandling(job, null, 14);
-      }
-    }
-  } finally {
-    flushIndex = 0;
-    queue.length = 0;
-    flushPostFlushCbs(seen);
-    isFlushing = false;
-    currentFlushPromise = null;
-    if (queue.length || pendingPreFlushCbs.length || pendingPostFlushCbs.length) {
-      flushJobs(seen);
-    }
-  }
-}
-function checkRecursiveUpdates(seen, fn) {
-  if (!seen.has(fn)) {
-    seen.set(fn, 1);
-  } else {
-    const count = seen.get(fn);
-    if (count > RECURSION_LIMIT) {
-      const instance = fn.ownerInstance;
-      const componentName = instance && getComponentName(instance.type);
-      warn$1(`Maximum recursive updates exceeded${componentName ? ` in component <${componentName}>` : ``}. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.`);
-      return true;
-    } else {
-      seen.set(fn, count + 1);
-    }
-  }
-}
-function emit(event, ...args) {
-}
-function devtoolsComponentEmit(component, event, params) {
-  emit("component:emit", component.appContext.app, component, event, params);
-}
-function emit$1(instance, event, ...rawArgs) {
-  if (instance.isUnmounted)
-    return;
-  const props = instance.vnode.props || EMPTY_OBJ;
-  {
-    const { emitsOptions, propsOptions: [propsOptions] } = instance;
-    if (emitsOptions) {
-      if (!(event in emitsOptions) && true) {
-        if (!propsOptions || !(toHandlerKey(event) in propsOptions)) {
-          warn$1(`Component emitted event "${event}" but it is neither declared in the emits option nor as an "${toHandlerKey(event)}" prop.`);
-        }
-      } else {
-        const validator = emitsOptions[event];
-        if (isFunction(validator)) {
-          const isValid = validator(...rawArgs);
-          if (!isValid) {
-            warn$1(`Invalid event arguments: event validation failed for event "${event}".`);
-          }
-        }
-      }
-    }
-  }
-  let args = rawArgs;
-  const isModelListener2 = event.startsWith("update:");
-  const modelArg = isModelListener2 && event.slice(7);
-  if (modelArg && modelArg in props) {
-    const modifiersKey = `${modelArg === "modelValue" ? "model" : modelArg}Modifiers`;
-    const { number, trim } = props[modifiersKey] || EMPTY_OBJ;
-    if (trim) {
-      args = rawArgs.map((a) => a.trim());
-    }
-    if (number) {
-      args = rawArgs.map(toNumber);
-    }
-  }
-  {
-    devtoolsComponentEmit(instance, event, args);
-  }
-  {
-    const lowerCaseEvent = event.toLowerCase();
-    if (lowerCaseEvent !== event && props[toHandlerKey(lowerCaseEvent)]) {
-      warn$1(`Event "${lowerCaseEvent}" is emitted in component ${formatComponentName(instance, instance.type)} but the handler is registered for "${event}". Note that HTML attributes are case-insensitive and you cannot use v-on to listen to camelCase events when using in-DOM templates. You should probably use "${hyphenate(event)}" instead of "${event}".`);
-    }
-  }
-  let handlerName;
-  let handler = props[handlerName = toHandlerKey(event)] || props[handlerName = toHandlerKey(camelize(event))];
-  if (!handler && isModelListener2) {
-    handler = props[handlerName = toHandlerKey(hyphenate(event))];
-  }
-  if (handler) {
-    callWithAsyncErrorHandling(handler, instance, 6, args);
-  }
-  const onceHandler = props[handlerName + `Once`];
-  if (onceHandler) {
-    if (!instance.emitted) {
-      instance.emitted = {};
-    } else if (instance.emitted[handlerName]) {
-      return;
-    }
-    instance.emitted[handlerName] = true;
-    callWithAsyncErrorHandling(onceHandler, instance, 6, args);
-  }
-}
-function normalizeEmitsOptions(comp, appContext, asMixin = false) {
-  const cache = appContext.emitsCache;
-  const cached = cache.get(comp);
-  if (cached !== void 0) {
-    return cached;
-  }
-  const raw = comp.emits;
-  let normalized = {};
-  let hasExtends = false;
-  if (!isFunction(comp)) {
-    const extendEmits = (raw2) => {
-      const normalizedFromExtend = normalizeEmitsOptions(raw2, appContext, true);
-      if (normalizedFromExtend) {
-        hasExtends = true;
-        extend(normalized, normalizedFromExtend);
-      }
-    };
-    if (!asMixin && appContext.mixins.length) {
-      appContext.mixins.forEach(extendEmits);
-    }
-    if (comp.extends) {
-      extendEmits(comp.extends);
-    }
-    if (comp.mixins) {
-      comp.mixins.forEach(extendEmits);
-    }
-  }
-  if (!raw && !hasExtends) {
-    cache.set(comp, null);
-    return null;
-  }
-  if (isArray(raw)) {
-    raw.forEach((key) => normalized[key] = null);
-  } else {
-    extend(normalized, raw);
-  }
-  cache.set(comp, normalized);
-  return normalized;
-}
-function isEmitListener(options, key) {
-  if (!options || !isOn(key)) {
-    return false;
-  }
-  key = key.slice(2).replace(/Once$/, "");
-  return hasOwn(options, key[0].toLowerCase() + key.slice(1)) || hasOwn(options, hyphenate(key)) || hasOwn(options, key);
-}
-let currentRenderingInstance = null;
-function setCurrentRenderingInstance(instance) {
-  const prev = currentRenderingInstance;
-  currentRenderingInstance = instance;
-  instance && instance.type.__scopeId || null;
-  return prev;
-}
-function provide(key, value) {
-  if (!currentInstance) {
-    {
-      warn$1(`provide() can only be used inside setup().`);
-    }
-  } else {
-    let provides = currentInstance.provides;
-    const parentProvides = currentInstance.parent && currentInstance.parent.provides;
-    if (parentProvides === provides) {
-      provides = currentInstance.provides = Object.create(parentProvides);
-    }
-    provides[key] = value;
-    if (currentInstance.type.mpType === "app") {
-      currentInstance.appContext.app.provide(key, value);
-    }
-  }
-}
-function inject(key, defaultValue, treatDefaultAsFactory = false) {
-  const instance = currentInstance || currentRenderingInstance;
-  if (instance) {
-    const provides = instance.parent == null ? instance.vnode.appContext && instance.vnode.appContext.provides : instance.parent.provides;
-    if (provides && key in provides) {
-      return provides[key];
-    } else if (arguments.length > 1) {
-      return treatDefaultAsFactory && isFunction(defaultValue) ? defaultValue.call(instance.proxy) : defaultValue;
-    } else {
-      warn$1(`injection "${String(key)}" not found.`);
-    }
-  } else {
-    warn$1(`inject() can only be used inside setup() or functional components.`);
-  }
-}
-function watchEffect(effect, options) {
-  return doWatch(effect, null, options);
-}
-const INITIAL_WATCHER_VALUE = {};
-function watch(source, cb, options) {
-  if (!isFunction(cb)) {
-    warn$1(`\`watch(fn, options?)\` signature has been moved to a separate API. Use \`watchEffect(fn, options?)\` instead. \`watch\` now only supports \`watch(source, cb, options?) signature.`);
-  }
-  return doWatch(source, cb, options);
-}
-function doWatch(source, cb, { immediate, deep, flush, onTrack, onTrigger } = EMPTY_OBJ) {
-  if (!cb) {
-    if (immediate !== void 0) {
-      warn$1(`watch() "immediate" option is only respected when using the watch(source, callback, options?) signature.`);
-    }
-    if (deep !== void 0) {
-      warn$1(`watch() "deep" option is only respected when using the watch(source, callback, options?) signature.`);
-    }
-  }
-  const warnInvalidSource = (s2) => {
-    warn$1(`Invalid watch source: `, s2, `A watch source can only be a getter/effect function, a ref, a reactive object, or an array of these types.`);
-  };
-  const instance = currentInstance;
-  let getter;
-  let forceTrigger = false;
-  let isMultiSource = false;
-  if (isRef(source)) {
-    getter = () => source.value;
-    forceTrigger = isShallow(source);
-  } else if (isReactive(source)) {
-    getter = () => source;
-    deep = true;
-  } else if (isArray(source)) {
-    isMultiSource = true;
-    forceTrigger = source.some((s2) => isReactive(s2) || isShallow(s2));
-    getter = () => source.map((s2) => {
-      if (isRef(s2)) {
-        return s2.value;
-      } else if (isReactive(s2)) {
-        return traverse(s2);
-      } else if (isFunction(s2)) {
-        return callWithErrorHandling(s2, instance, 2);
-      } else {
-        warnInvalidSource(s2);
-      }
-    });
-  } else if (isFunction(source)) {
-    if (cb) {
-      getter = () => callWithErrorHandling(source, instance, 2);
-    } else {
-      getter = () => {
-        if (instance && instance.isUnmounted) {
-          return;
-        }
-        if (cleanup) {
-          cleanup();
-        }
-        return callWithAsyncErrorHandling(source, instance, 3, [onCleanup]);
-      };
-    }
-  } else {
-    getter = NOOP;
-    warnInvalidSource(source);
-  }
-  if (cb && deep) {
-    const baseGetter = getter;
-    getter = () => traverse(baseGetter());
-  }
-  let cleanup;
-  let onCleanup = (fn) => {
-    cleanup = effect.onStop = () => {
-      callWithErrorHandling(fn, instance, 4);
-    };
-  };
-  let oldValue = isMultiSource ? [] : INITIAL_WATCHER_VALUE;
-  const job = () => {
-    if (!effect.active) {
-      return;
-    }
-    if (cb) {
-      const newValue = effect.run();
-      if (deep || forceTrigger || (isMultiSource ? newValue.some((v, i) => hasChanged(v, oldValue[i])) : hasChanged(newValue, oldValue)) || false) {
-        if (cleanup) {
-          cleanup();
-        }
-        callWithAsyncErrorHandling(cb, instance, 3, [
-          newValue,
-          oldValue === INITIAL_WATCHER_VALUE ? void 0 : oldValue,
-          onCleanup
-        ]);
-        oldValue = newValue;
-      }
-    } else {
-      effect.run();
-    }
-  };
-  job.allowRecurse = !!cb;
-  let scheduler;
-  if (flush === "sync") {
-    scheduler = job;
-  } else if (flush === "post") {
-    scheduler = () => queuePostRenderEffect(job, instance && instance.suspense);
-  } else {
-    scheduler = () => {
-      if (!instance || instance.isMounted) {
-        queuePreFlushCb(job);
-      } else {
-        job();
-      }
-    };
-  }
-  const effect = new ReactiveEffect(getter, scheduler);
-  {
-    effect.onTrack = onTrack;
-    effect.onTrigger = onTrigger;
-  }
-  if (cb) {
-    if (immediate) {
-      job();
-    } else {
-      oldValue = effect.run();
-    }
-  } else if (flush === "post") {
-    queuePostRenderEffect(effect.run.bind(effect), instance && instance.suspense);
-  } else {
-    effect.run();
-  }
-  return () => {
-    effect.stop();
-    if (instance && instance.scope) {
-      remove(instance.scope.effects, effect);
-    }
-  };
-}
-function instanceWatch(source, value, options) {
-  const publicThis = this.proxy;
-  const getter = isString(source) ? source.includes(".") ? createPathGetter(publicThis, source) : () => publicThis[source] : source.bind(publicThis, publicThis);
-  let cb;
-  if (isFunction(value)) {
-    cb = value;
-  } else {
-    cb = value.handler;
-    options = value;
-  }
-  const cur = currentInstance;
-  setCurrentInstance(this);
-  const res = doWatch(getter, cb.bind(publicThis), options);
-  if (cur) {
-    setCurrentInstance(cur);
-  } else {
-    unsetCurrentInstance();
-  }
-  return res;
-}
-function createPathGetter(ctx, path) {
-  const segments = path.split(".");
-  return () => {
-    let cur = ctx;
-    for (let i = 0; i < segments.length && cur; i++) {
-      cur = cur[segments[i]];
-    }
-    return cur;
-  };
-}
-function traverse(value, seen) {
-  if (!isObject$1(value) || value["__v_skip"]) {
-    return value;
-  }
-  seen = seen || /* @__PURE__ */ new Set();
-  if (seen.has(value)) {
-    return value;
-  }
-  seen.add(value);
-  if (isRef(value)) {
-    traverse(value.value, seen);
-  } else if (isArray(value)) {
-    for (let i = 0; i < value.length; i++) {
-      traverse(value[i], seen);
-    }
-  } else if (isSet(value) || isMap(value)) {
-    value.forEach((v) => {
-      traverse(v, seen);
-    });
-  } else if (isPlainObject(value)) {
-    for (const key in value) {
-      traverse(value[key], seen);
-    }
-  }
-  return value;
-}
-function defineComponent(options) {
-  return isFunction(options) ? { setup: options, name: options.name } : options;
-}
-const isKeepAlive = (vnode) => vnode.type.__isKeepAlive;
-function onActivated(hook, target) {
-  registerKeepAliveHook(hook, "a", target);
-}
-function onDeactivated(hook, target) {
-  registerKeepAliveHook(hook, "da", target);
-}
-function registerKeepAliveHook(hook, type, target = currentInstance) {
-  const wrappedHook = hook.__wdc || (hook.__wdc = () => {
-    let current = target;
-    while (current) {
-      if (current.isDeactivated) {
-        return;
-      }
-      current = current.parent;
-    }
-    return hook();
-  });
-  injectHook(type, wrappedHook, target);
-  if (target) {
-    let current = target.parent;
-    while (current && current.parent) {
-      if (isKeepAlive(current.parent.vnode)) {
-        injectToKeepAliveRoot(wrappedHook, type, target, current);
-      }
-      current = current.parent;
-    }
-  }
-}
-function injectToKeepAliveRoot(hook, type, target, keepAliveRoot) {
-  const injected = injectHook(type, hook, keepAliveRoot, true);
-  onUnmounted(() => {
-    remove(keepAliveRoot[type], injected);
-  }, target);
-}
-function injectHook(type, hook, target = currentInstance, prepend = false) {
-  if (target) {
-    if (isRootHook(type)) {
-      target = target.root;
-    }
-    const hooks = target[type] || (target[type] = []);
-    const wrappedHook = hook.__weh || (hook.__weh = (...args) => {
-      if (target.isUnmounted) {
-        return;
-      }
-      pauseTracking();
-      setCurrentInstance(target);
-      const res = callWithAsyncErrorHandling(hook, target, type, args);
-      unsetCurrentInstance();
-      resetTracking();
-      return res;
-    });
-    if (prepend) {
-      hooks.unshift(wrappedHook);
-    } else {
-      hooks.push(wrappedHook);
-    }
-    return wrappedHook;
-  } else {
-    const apiName = toHandlerKey((ErrorTypeStrings[type] || type.replace(/^on/, "")).replace(/ hook$/, ""));
-    warn$1(`${apiName} is called when there is no active component instance to be associated with. Lifecycle injection APIs can only be used during execution of setup().`);
-  }
-}
-const createHook$1 = (lifecycle) => (hook, target = currentInstance) => (!isInSSRComponentSetup || lifecycle === "sp") && injectHook(lifecycle, hook, target);
-const onBeforeMount = createHook$1("bm");
-const onMounted = createHook$1("m");
-const onBeforeUpdate = createHook$1("bu");
-const onUpdated = createHook$1("u");
-const onBeforeUnmount = createHook$1("bum");
-const onUnmounted = createHook$1("um");
-const onServerPrefetch = createHook$1("sp");
-const onRenderTriggered = createHook$1("rtg");
-const onRenderTracked = createHook$1("rtc");
-function onErrorCaptured(hook, target = currentInstance) {
-  injectHook("ec", hook, target);
-}
-function validateDirectiveName(name) {
-  if (isBuiltInDirective(name)) {
-    warn$1("Do not use built-in directive ids as custom directive id: " + name);
-  }
-}
-const COMPONENTS = "components";
-function resolveComponent(name, maybeSelfReference) {
-  return resolveAsset(COMPONENTS, name, true, maybeSelfReference) || name;
-}
-function resolveAsset(type, name, warnMissing = true, maybeSelfReference = false) {
-  const instance = currentRenderingInstance || currentInstance;
-  if (instance) {
-    const Component2 = instance.type;
-    if (type === COMPONENTS) {
-      const selfName = getComponentName(Component2, false);
-      if (selfName && (selfName === name || selfName === camelize(name) || selfName === capitalize(camelize(name)))) {
-        return Component2;
-      }
-    }
-    const res = resolve(instance[type] || Component2[type], name) || resolve(instance.appContext[type], name);
-    if (!res && maybeSelfReference) {
-      return Component2;
-    }
-    if (warnMissing && !res) {
-      const extra = type === COMPONENTS ? `
-If this is a native custom element, make sure to exclude it from component resolution via compilerOptions.isCustomElement.` : ``;
-      warn$1(`Failed to resolve ${type.slice(0, -1)}: ${name}${extra}`);
-    }
-    return res;
-  } else {
-    warn$1(`resolve${capitalize(type.slice(0, -1))} can only be used in render() or setup().`);
-  }
-}
-function resolve(registry, name) {
-  return registry && (registry[name] || registry[camelize(name)] || registry[capitalize(camelize(name))]);
-}
-const getPublicInstance = (i) => {
-  if (!i)
-    return null;
-  if (isStatefulComponent(i))
-    return getExposeProxy(i) || i.proxy;
-  return getPublicInstance(i.parent);
-};
-const publicPropertiesMap = /* @__PURE__ */ extend(/* @__PURE__ */ Object.create(null), {
-  $: (i) => i,
-  $el: (i) => i.__$el || (i.__$el = {}),
-  $data: (i) => i.data,
-  $props: (i) => shallowReadonly(i.props),
-  $attrs: (i) => shallowReadonly(i.attrs),
-  $slots: (i) => shallowReadonly(i.slots),
-  $refs: (i) => shallowReadonly(i.refs),
-  $parent: (i) => getPublicInstance(i.parent),
-  $root: (i) => getPublicInstance(i.root),
-  $emit: (i) => i.emit,
-  $options: (i) => resolveMergedOptions(i),
-  $forceUpdate: (i) => i.f || (i.f = () => queueJob(i.update)),
-  $watch: (i) => instanceWatch.bind(i)
-});
-const isReservedPrefix = (key) => key === "_" || key === "$";
-const PublicInstanceProxyHandlers = {
-  get({ _: instance }, key) {
-    const { ctx, setupState, data, props, accessCache, type, appContext } = instance;
-    if (key === "__isVue") {
-      return true;
-    }
-    if (setupState !== EMPTY_OBJ && setupState.__isScriptSetup && hasOwn(setupState, key)) {
-      return setupState[key];
-    }
-    let normalizedProps;
-    if (key[0] !== "$") {
-      const n2 = accessCache[key];
-      if (n2 !== void 0) {
-        switch (n2) {
-          case 1:
-            return setupState[key];
-          case 2:
-            return data[key];
-          case 4:
-            return ctx[key];
-          case 3:
-            return props[key];
-        }
-      } else if (setupState !== EMPTY_OBJ && hasOwn(setupState, key)) {
-        accessCache[key] = 1;
-        return setupState[key];
-      } else if (data !== EMPTY_OBJ && hasOwn(data, key)) {
-        accessCache[key] = 2;
-        return data[key];
-      } else if ((normalizedProps = instance.propsOptions[0]) && hasOwn(normalizedProps, key)) {
-        accessCache[key] = 3;
-        return props[key];
-      } else if (ctx !== EMPTY_OBJ && hasOwn(ctx, key)) {
-        accessCache[key] = 4;
-        return ctx[key];
-      } else if (shouldCacheAccess) {
-        accessCache[key] = 0;
-      }
-    }
-    const publicGetter = publicPropertiesMap[key];
-    let cssModule, globalProperties;
-    if (publicGetter) {
-      if (key === "$attrs") {
-        track(instance, "get", key);
-      }
-      return publicGetter(instance);
-    } else if ((cssModule = type.__cssModules) && (cssModule = cssModule[key])) {
-      return cssModule;
-    } else if (ctx !== EMPTY_OBJ && hasOwn(ctx, key)) {
-      accessCache[key] = 4;
-      return ctx[key];
-    } else if (globalProperties = appContext.config.globalProperties, hasOwn(globalProperties, key)) {
-      {
-        return globalProperties[key];
-      }
-    } else if (currentRenderingInstance && (!isString(key) || key.indexOf("__v") !== 0)) {
-      if (data !== EMPTY_OBJ && isReservedPrefix(key[0]) && hasOwn(data, key)) {
-        warn$1(`Property ${JSON.stringify(key)} must be accessed via $data because it starts with a reserved character ("$" or "_") and is not proxied on the render context.`);
-      } else if (instance === currentRenderingInstance) {
-        warn$1(`Property ${JSON.stringify(key)} was accessed during render but is not defined on instance.`);
-      }
-    }
-  },
-  set({ _: instance }, key, value) {
-    const { data, setupState, ctx } = instance;
-    if (setupState !== EMPTY_OBJ && hasOwn(setupState, key)) {
-      setupState[key] = value;
-      return true;
-    } else if (data !== EMPTY_OBJ && hasOwn(data, key)) {
-      data[key] = value;
-      return true;
-    } else if (hasOwn(instance.props, key)) {
-      warn$1(`Attempting to mutate prop "${key}". Props are readonly.`, instance);
-      return false;
-    }
-    if (key[0] === "$" && key.slice(1) in instance) {
-      warn$1(`Attempting to mutate public property "${key}". Properties starting with $ are reserved and readonly.`, instance);
-      return false;
-    } else {
-      if (key in instance.appContext.config.globalProperties) {
-        Object.defineProperty(ctx, key, {
-          enumerable: true,
-          configurable: true,
-          value
-        });
-      } else {
-        ctx[key] = value;
-      }
-    }
-    return true;
-  },
-  has({ _: { data, setupState, accessCache, ctx, appContext, propsOptions } }, key) {
-    let normalizedProps;
-    return !!accessCache[key] || data !== EMPTY_OBJ && hasOwn(data, key) || setupState !== EMPTY_OBJ && hasOwn(setupState, key) || (normalizedProps = propsOptions[0]) && hasOwn(normalizedProps, key) || hasOwn(ctx, key) || hasOwn(publicPropertiesMap, key) || hasOwn(appContext.config.globalProperties, key);
-  },
-  defineProperty(target, key, descriptor) {
-    if (descriptor.get != null) {
-      target._.accessCache[key] = 0;
-    } else if (hasOwn(descriptor, "value")) {
-      this.set(target, key, descriptor.value, null);
-    }
-    return Reflect.defineProperty(target, key, descriptor);
-  }
-};
-{
-  PublicInstanceProxyHandlers.ownKeys = (target) => {
-    warn$1(`Avoid app logic that relies on enumerating keys on a component instance. The keys will be empty in production mode to avoid performance overhead.`);
-    return Reflect.ownKeys(target);
-  };
-}
-function createDevRenderContext(instance) {
-  const target = {};
-  Object.defineProperty(target, `_`, {
-    configurable: true,
-    enumerable: false,
-    get: () => instance
-  });
-  Object.keys(publicPropertiesMap).forEach((key) => {
-    Object.defineProperty(target, key, {
-      configurable: true,
-      enumerable: false,
-      get: () => publicPropertiesMap[key](instance),
-      set: NOOP
-    });
-  });
-  return target;
-}
-function exposePropsOnRenderContext(instance) {
-  const { ctx, propsOptions: [propsOptions] } = instance;
-  if (propsOptions) {
-    Object.keys(propsOptions).forEach((key) => {
-      Object.defineProperty(ctx, key, {
-        enumerable: true,
-        configurable: true,
-        get: () => instance.props[key],
-        set: NOOP
-      });
-    });
-  }
-}
-function exposeSetupStateOnRenderContext(instance) {
-  const { ctx, setupState } = instance;
-  Object.keys(toRaw(setupState)).forEach((key) => {
-    if (!setupState.__isScriptSetup) {
-      if (isReservedPrefix(key[0])) {
-        warn$1(`setup() return property ${JSON.stringify(key)} should not start with "$" or "_" which are reserved prefixes for Vue internals.`);
-        return;
-      }
-      Object.defineProperty(ctx, key, {
-        enumerable: true,
-        configurable: true,
-        get: () => setupState[key],
-        set: NOOP
-      });
-    }
-  });
-}
-function createDuplicateChecker() {
-  const cache = /* @__PURE__ */ Object.create(null);
-  return (type, key) => {
-    if (cache[key]) {
-      warn$1(`${type} property "${key}" is already defined in ${cache[key]}.`);
-    } else {
-      cache[key] = type;
-    }
-  };
-}
-let shouldCacheAccess = true;
-function applyOptions$1(instance) {
-  const options = resolveMergedOptions(instance);
-  const publicThis = instance.proxy;
-  const ctx = instance.ctx;
-  shouldCacheAccess = false;
-  if (options.beforeCreate) {
-    callHook$1(options.beforeCreate, instance, "bc");
-  }
-  const {
-    data: dataOptions,
-    computed: computedOptions,
-    methods,
-    watch: watchOptions,
-    provide: provideOptions,
-    inject: injectOptions,
-    created,
-    beforeMount,
-    mounted,
-    beforeUpdate,
-    updated,
-    activated,
-    deactivated,
-    beforeDestroy,
-    beforeUnmount,
-    destroyed,
-    unmounted,
-    render,
-    renderTracked,
-    renderTriggered,
-    errorCaptured,
-    serverPrefetch,
-    expose,
-    inheritAttrs,
-    components,
-    directives,
-    filters
-  } = options;
-  const checkDuplicateProperties = createDuplicateChecker();
-  {
-    const [propsOptions] = instance.propsOptions;
-    if (propsOptions) {
-      for (const key in propsOptions) {
-        checkDuplicateProperties("Props", key);
-      }
-    }
-  }
-  if (injectOptions) {
-    resolveInjections(injectOptions, ctx, checkDuplicateProperties, instance.appContext.config.unwrapInjectedRef);
-  }
-  if (methods) {
-    for (const key in methods) {
-      const methodHandler = methods[key];
-      if (isFunction(methodHandler)) {
-        {
-          Object.defineProperty(ctx, key, {
-            value: methodHandler.bind(publicThis),
-            configurable: true,
-            enumerable: true,
-            writable: true
-          });
-        }
-        {
-          checkDuplicateProperties("Methods", key);
-        }
-      } else {
-        warn$1(`Method "${key}" has type "${typeof methodHandler}" in the component definition. Did you reference the function correctly?`);
-      }
-    }
-  }
-  if (dataOptions) {
-    if (!isFunction(dataOptions)) {
-      warn$1(`The data option must be a function. Plain object usage is no longer supported.`);
-    }
-    const data = dataOptions.call(publicThis, publicThis);
-    if (isPromise$1(data)) {
-      warn$1(`data() returned a Promise - note data() cannot be async; If you intend to perform data fetching before component renders, use async setup() + <Suspense>.`);
-    }
-    if (!isObject$1(data)) {
-      warn$1(`data() should return an object.`);
-    } else {
-      instance.data = reactive(data);
-      {
-        for (const key in data) {
-          checkDuplicateProperties("Data", key);
-          if (!isReservedPrefix(key[0])) {
-            Object.defineProperty(ctx, key, {
-              configurable: true,
-              enumerable: true,
-              get: () => data[key],
-              set: NOOP
-            });
-          }
-        }
-      }
-    }
-  }
-  shouldCacheAccess = true;
-  if (computedOptions) {
-    for (const key in computedOptions) {
-      const opt = computedOptions[key];
-      const get3 = isFunction(opt) ? opt.bind(publicThis, publicThis) : isFunction(opt.get) ? opt.get.bind(publicThis, publicThis) : NOOP;
-      if (get3 === NOOP) {
-        warn$1(`Computed property "${key}" has no getter.`);
-      }
-      const set2 = !isFunction(opt) && isFunction(opt.set) ? opt.set.bind(publicThis) : () => {
-        warn$1(`Write operation failed: computed property "${key}" is readonly.`);
-      };
-      const c = computed$1({
-        get: get3,
-        set: set2
-      });
-      Object.defineProperty(ctx, key, {
-        enumerable: true,
-        configurable: true,
-        get: () => c.value,
-        set: (v) => c.value = v
-      });
-      {
-        checkDuplicateProperties("Computed", key);
-      }
-    }
-  }
-  if (watchOptions) {
-    for (const key in watchOptions) {
-      createWatcher(watchOptions[key], ctx, publicThis, key);
-    }
-  }
-  {
-    if (provideOptions) {
-      const provides = isFunction(provideOptions) ? provideOptions.call(publicThis) : provideOptions;
-      Reflect.ownKeys(provides).forEach((key) => {
-        provide(key, provides[key]);
-      });
-    }
-  }
-  {
-    if (created) {
-      callHook$1(created, instance, "c");
-    }
-  }
-  function registerLifecycleHook(register2, hook) {
-    if (isArray(hook)) {
-      hook.forEach((_hook) => register2(_hook.bind(publicThis)));
-    } else if (hook) {
-      register2(hook.bind(publicThis));
-    }
-  }
-  registerLifecycleHook(onBeforeMount, beforeMount);
-  registerLifecycleHook(onMounted, mounted);
-  registerLifecycleHook(onBeforeUpdate, beforeUpdate);
-  registerLifecycleHook(onUpdated, updated);
-  registerLifecycleHook(onActivated, activated);
-  registerLifecycleHook(onDeactivated, deactivated);
-  registerLifecycleHook(onErrorCaptured, errorCaptured);
-  registerLifecycleHook(onRenderTracked, renderTracked);
-  registerLifecycleHook(onRenderTriggered, renderTriggered);
-  registerLifecycleHook(onBeforeUnmount, beforeUnmount);
-  registerLifecycleHook(onUnmounted, unmounted);
-  registerLifecycleHook(onServerPrefetch, serverPrefetch);
-  if (isArray(expose)) {
-    if (expose.length) {
-      const exposed = instance.exposed || (instance.exposed = {});
-      expose.forEach((key) => {
-        Object.defineProperty(exposed, key, {
-          get: () => publicThis[key],
-          set: (val) => publicThis[key] = val
-        });
-      });
-    } else if (!instance.exposed) {
-      instance.exposed = {};
-    }
-  }
-  if (render && instance.render === NOOP) {
-    instance.render = render;
-  }
-  if (inheritAttrs != null) {
-    instance.inheritAttrs = inheritAttrs;
-  }
-  if (components)
-    instance.components = components;
-  if (directives)
-    instance.directives = directives;
-  if (instance.ctx.$onApplyOptions) {
-    instance.ctx.$onApplyOptions(options, instance, publicThis);
-  }
-}
-function resolveInjections(injectOptions, ctx, checkDuplicateProperties = NOOP, unwrapRef = false) {
-  if (isArray(injectOptions)) {
-    injectOptions = normalizeInject(injectOptions);
-  }
-  for (const key in injectOptions) {
-    const opt = injectOptions[key];
-    let injected;
-    if (isObject$1(opt)) {
-      if ("default" in opt) {
-        injected = inject(opt.from || key, opt.default, true);
-      } else {
-        injected = inject(opt.from || key);
-      }
-    } else {
-      injected = inject(opt);
-    }
-    if (isRef(injected)) {
-      if (unwrapRef) {
-        Object.defineProperty(ctx, key, {
-          enumerable: true,
-          configurable: true,
-          get: () => injected.value,
-          set: (v) => injected.value = v
-        });
-      } else {
-        {
-          warn$1(`injected property "${key}" is a ref and will be auto-unwrapped and no longer needs \`.value\` in the next minor release. To opt-in to the new behavior now, set \`app.config.unwrapInjectedRef = true\` (this config is temporary and will not be needed in the future.)`);
-        }
-        ctx[key] = injected;
-      }
-    } else {
-      ctx[key] = injected;
-    }
-    {
-      checkDuplicateProperties("Inject", key);
-    }
-  }
-}
-function callHook$1(hook, instance, type) {
-  callWithAsyncErrorHandling(isArray(hook) ? hook.map((h) => h.bind(instance.proxy)) : hook.bind(instance.proxy), instance, type);
-}
-function createWatcher(raw, ctx, publicThis, key) {
-  const getter = key.includes(".") ? createPathGetter(publicThis, key) : () => publicThis[key];
-  if (isString(raw)) {
-    const handler = ctx[raw];
-    if (isFunction(handler)) {
-      watch(getter, handler);
-    } else {
-      warn$1(`Invalid watch handler specified by key "${raw}"`, handler);
-    }
-  } else if (isFunction(raw)) {
-    watch(getter, raw.bind(publicThis));
-  } else if (isObject$1(raw)) {
-    if (isArray(raw)) {
-      raw.forEach((r) => createWatcher(r, ctx, publicThis, key));
-    } else {
-      const handler = isFunction(raw.handler) ? raw.handler.bind(publicThis) : ctx[raw.handler];
-      if (isFunction(handler)) {
-        watch(getter, handler, raw);
-      } else {
-        warn$1(`Invalid watch handler specified by key "${raw.handler}"`, handler);
-      }
-    }
-  } else {
-    warn$1(`Invalid watch option: "${key}"`, raw);
-  }
-}
-function resolveMergedOptions(instance) {
-  const base = instance.type;
-  const { mixins, extends: extendsOptions } = base;
-  const { mixins: globalMixins, optionsCache: cache, config: { optionMergeStrategies } } = instance.appContext;
-  const cached = cache.get(base);
-  let resolved;
-  if (cached) {
-    resolved = cached;
-  } else if (!globalMixins.length && !mixins && !extendsOptions) {
-    {
-      resolved = base;
-    }
-  } else {
-    resolved = {};
-    if (globalMixins.length) {
-      globalMixins.forEach((m) => mergeOptions(resolved, m, optionMergeStrategies, true));
-    }
-    mergeOptions(resolved, base, optionMergeStrategies);
-  }
-  cache.set(base, resolved);
-  return resolved;
-}
-function mergeOptions(to, from, strats, asMixin = false) {
-  const { mixins, extends: extendsOptions } = from;
-  if (extendsOptions) {
-    mergeOptions(to, extendsOptions, strats, true);
-  }
-  if (mixins) {
-    mixins.forEach((m) => mergeOptions(to, m, strats, true));
-  }
-  for (const key in from) {
-    if (asMixin && key === "expose") {
-      warn$1(`"expose" option is ignored when declared in mixins or extends. It should only be declared in the base component itself.`);
-    } else {
-      const strat = internalOptionMergeStrats[key] || strats && strats[key];
-      to[key] = strat ? strat(to[key], from[key]) : from[key];
-    }
-  }
-  return to;
-}
-const internalOptionMergeStrats = {
-  data: mergeDataFn,
-  props: mergeObjectOptions,
-  emits: mergeObjectOptions,
-  methods: mergeObjectOptions,
-  computed: mergeObjectOptions,
-  beforeCreate: mergeAsArray$1,
-  created: mergeAsArray$1,
-  beforeMount: mergeAsArray$1,
-  mounted: mergeAsArray$1,
-  beforeUpdate: mergeAsArray$1,
-  updated: mergeAsArray$1,
-  beforeDestroy: mergeAsArray$1,
-  beforeUnmount: mergeAsArray$1,
-  destroyed: mergeAsArray$1,
-  unmounted: mergeAsArray$1,
-  activated: mergeAsArray$1,
-  deactivated: mergeAsArray$1,
-  errorCaptured: mergeAsArray$1,
-  serverPrefetch: mergeAsArray$1,
-  components: mergeObjectOptions,
-  directives: mergeObjectOptions,
-  watch: mergeWatchOptions,
-  provide: mergeDataFn,
-  inject: mergeInject
-};
-function mergeDataFn(to, from) {
-  if (!from) {
-    return to;
-  }
-  if (!to) {
-    return from;
-  }
-  return function mergedDataFn() {
-    return extend(isFunction(to) ? to.call(this, this) : to, isFunction(from) ? from.call(this, this) : from);
-  };
-}
-function mergeInject(to, from) {
-  return mergeObjectOptions(normalizeInject(to), normalizeInject(from));
-}
-function normalizeInject(raw) {
-  if (isArray(raw)) {
-    const res = {};
-    for (let i = 0; i < raw.length; i++) {
-      res[raw[i]] = raw[i];
-    }
-    return res;
-  }
-  return raw;
-}
-function mergeAsArray$1(to, from) {
-  return to ? [...new Set([].concat(to, from))] : from;
-}
-function mergeObjectOptions(to, from) {
-  return to ? extend(extend(/* @__PURE__ */ Object.create(null), to), from) : from;
-}
-function mergeWatchOptions(to, from) {
-  if (!to)
-    return from;
-  if (!from)
-    return to;
-  const merged = extend(/* @__PURE__ */ Object.create(null), to);
-  for (const key in from) {
-    merged[key] = mergeAsArray$1(to[key], from[key]);
-  }
-  return merged;
-}
-function initProps$1(instance, rawProps, isStateful, isSSR = false) {
-  const props = {};
-  const attrs = {};
-  instance.propsDefaults = /* @__PURE__ */ Object.create(null);
-  setFullProps(instance, rawProps, props, attrs);
-  for (const key in instance.propsOptions[0]) {
-    if (!(key in props)) {
-      props[key] = void 0;
-    }
-  }
-  {
-    validateProps(rawProps || {}, props, instance);
-  }
-  if (isStateful) {
-    instance.props = isSSR ? props : shallowReactive(props);
-  } else {
-    if (!instance.type.props) {
-      instance.props = attrs;
-    } else {
-      instance.props = props;
-    }
-  }
-  instance.attrs = attrs;
-}
-function updateProps(instance, rawProps, rawPrevProps, optimized) {
-  const { props, attrs, vnode: { patchFlag } } = instance;
-  const rawCurrentProps = toRaw(props);
-  const [options] = instance.propsOptions;
-  let hasAttrsChanged = false;
-  if (!(instance.type.__hmrId || instance.parent && instance.parent.type.__hmrId) && (optimized || patchFlag > 0) && !(patchFlag & 16)) {
-    if (patchFlag & 8) {
-      const propsToUpdate = instance.vnode.dynamicProps;
-      for (let i = 0; i < propsToUpdate.length; i++) {
-        let key = propsToUpdate[i];
-        if (isEmitListener(instance.emitsOptions, key)) {
-          continue;
-        }
-        const value = rawProps[key];
-        if (options) {
-          if (hasOwn(attrs, key)) {
-            if (value !== attrs[key]) {
-              attrs[key] = value;
-              hasAttrsChanged = true;
-            }
-          } else {
-            const camelizedKey = camelize(key);
-            props[camelizedKey] = resolvePropValue(options, rawCurrentProps, camelizedKey, value, instance, false);
-          }
-        } else {
-          if (value !== attrs[key]) {
-            attrs[key] = value;
-            hasAttrsChanged = true;
-          }
-        }
-      }
-    }
-  } else {
-    if (setFullProps(instance, rawProps, props, attrs)) {
-      hasAttrsChanged = true;
-    }
-    let kebabKey;
-    for (const key in rawCurrentProps) {
-      if (!rawProps || !hasOwn(rawProps, key) && ((kebabKey = hyphenate(key)) === key || !hasOwn(rawProps, kebabKey))) {
-        if (options) {
-          if (rawPrevProps && (rawPrevProps[key] !== void 0 || rawPrevProps[kebabKey] !== void 0)) {
-            props[key] = resolvePropValue(options, rawCurrentProps, key, void 0, instance, true);
-          }
-        } else {
-          delete props[key];
-        }
-      }
-    }
-    if (attrs !== rawCurrentProps) {
-      for (const key in attrs) {
-        if (!rawProps || !hasOwn(rawProps, key) && true) {
-          delete attrs[key];
-          hasAttrsChanged = true;
-        }
-      }
-    }
-  }
-  if (hasAttrsChanged) {
-    trigger(instance, "set", "$attrs");
-  }
-  {
-    validateProps(rawProps || {}, props, instance);
-  }
-}
-function setFullProps(instance, rawProps, props, attrs) {
-  const [options, needCastKeys] = instance.propsOptions;
-  let hasAttrsChanged = false;
-  let rawCastValues;
-  if (rawProps) {
-    for (let key in rawProps) {
-      if (isReservedProp(key)) {
-        continue;
-      }
-      const value = rawProps[key];
-      let camelKey;
-      if (options && hasOwn(options, camelKey = camelize(key))) {
-        if (!needCastKeys || !needCastKeys.includes(camelKey)) {
-          props[camelKey] = value;
-        } else {
-          (rawCastValues || (rawCastValues = {}))[camelKey] = value;
-        }
-      } else if (!isEmitListener(instance.emitsOptions, key)) {
-        if (!(key in attrs) || value !== attrs[key]) {
-          attrs[key] = value;
-          hasAttrsChanged = true;
-        }
-      }
-    }
-  }
-  if (needCastKeys) {
-    const rawCurrentProps = toRaw(props);
-    const castValues = rawCastValues || EMPTY_OBJ;
-    for (let i = 0; i < needCastKeys.length; i++) {
-      const key = needCastKeys[i];
-      props[key] = resolvePropValue(options, rawCurrentProps, key, castValues[key], instance, !hasOwn(castValues, key));
-    }
-  }
-  return hasAttrsChanged;
-}
-function resolvePropValue(options, props, key, value, instance, isAbsent) {
-  const opt = options[key];
-  if (opt != null) {
-    const hasDefault = hasOwn(opt, "default");
-    if (hasDefault && value === void 0) {
-      const defaultValue = opt.default;
-      if (opt.type !== Function && isFunction(defaultValue)) {
-        const { propsDefaults } = instance;
-        if (key in propsDefaults) {
-          value = propsDefaults[key];
-        } else {
-          setCurrentInstance(instance);
-          value = propsDefaults[key] = defaultValue.call(null, props);
-          unsetCurrentInstance();
-        }
-      } else {
-        value = defaultValue;
-      }
-    }
-    if (opt[0]) {
-      if (isAbsent && !hasDefault) {
-        value = false;
-      } else if (opt[1] && (value === "" || value === hyphenate(key))) {
-        value = true;
-      }
-    }
-  }
-  return value;
-}
-function normalizePropsOptions(comp, appContext, asMixin = false) {
-  const cache = appContext.propsCache;
-  const cached = cache.get(comp);
-  if (cached) {
-    return cached;
-  }
-  const raw = comp.props;
-  const normalized = {};
-  const needCastKeys = [];
-  let hasExtends = false;
-  if (!isFunction(comp)) {
-    const extendProps = (raw2) => {
-      hasExtends = true;
-      const [props, keys] = normalizePropsOptions(raw2, appContext, true);
-      extend(normalized, props);
-      if (keys)
-        needCastKeys.push(...keys);
-    };
-    if (!asMixin && appContext.mixins.length) {
-      appContext.mixins.forEach(extendProps);
-    }
-    if (comp.extends) {
-      extendProps(comp.extends);
-    }
-    if (comp.mixins) {
-      comp.mixins.forEach(extendProps);
-    }
-  }
-  if (!raw && !hasExtends) {
-    cache.set(comp, EMPTY_ARR);
-    return EMPTY_ARR;
-  }
-  if (isArray(raw)) {
-    for (let i = 0; i < raw.length; i++) {
-      if (!isString(raw[i])) {
-        warn$1(`props must be strings when using array syntax.`, raw[i]);
-      }
-      const normalizedKey = camelize(raw[i]);
-      if (validatePropName(normalizedKey)) {
-        normalized[normalizedKey] = EMPTY_OBJ;
-      }
-    }
-  } else if (raw) {
-    if (!isObject$1(raw)) {
-      warn$1(`invalid props options`, raw);
-    }
-    for (const key in raw) {
-      const normalizedKey = camelize(key);
-      if (validatePropName(normalizedKey)) {
-        const opt = raw[key];
-        const prop = normalized[normalizedKey] = isArray(opt) || isFunction(opt) ? { type: opt } : opt;
-        if (prop) {
-          const booleanIndex = getTypeIndex(Boolean, prop.type);
-          const stringIndex = getTypeIndex(String, prop.type);
-          prop[0] = booleanIndex > -1;
-          prop[1] = stringIndex < 0 || booleanIndex < stringIndex;
-          if (booleanIndex > -1 || hasOwn(prop, "default")) {
-            needCastKeys.push(normalizedKey);
-          }
-        }
-      }
-    }
-  }
-  const res = [normalized, needCastKeys];
-  cache.set(comp, res);
-  return res;
-}
-function validatePropName(key) {
-  if (key[0] !== "$") {
-    return true;
-  } else {
-    warn$1(`Invalid prop name: "${key}" is a reserved property.`);
-  }
-  return false;
-}
-function getType(ctor) {
-  const match = ctor && ctor.toString().match(/^\s*function (\w+)/);
-  return match ? match[1] : ctor === null ? "null" : "";
-}
-function isSameType(a, b) {
-  return getType(a) === getType(b);
-}
-function getTypeIndex(type, expectedTypes) {
-  if (isArray(expectedTypes)) {
-    return expectedTypes.findIndex((t2) => isSameType(t2, type));
-  } else if (isFunction(expectedTypes)) {
-    return isSameType(expectedTypes, type) ? 0 : -1;
-  }
-  return -1;
-}
-function validateProps(rawProps, props, instance) {
-  const resolvedValues = toRaw(props);
-  const options = instance.propsOptions[0];
-  for (const key in options) {
-    let opt = options[key];
-    if (opt == null)
-      continue;
-    validateProp(key, resolvedValues[key], opt, !hasOwn(rawProps, key) && !hasOwn(rawProps, hyphenate(key)));
-  }
-}
-function validateProp(name, value, prop, isAbsent) {
-  const { type, required, validator } = prop;
-  if (required && isAbsent) {
-    warn$1('Missing required prop: "' + name + '"');
-    return;
-  }
-  if (value == null && !prop.required) {
-    return;
-  }
-  if (type != null && type !== true) {
-    let isValid = false;
-    const types = isArray(type) ? type : [type];
-    const expectedTypes = [];
-    for (let i = 0; i < types.length && !isValid; i++) {
-      const { valid, expectedType } = assertType(value, types[i]);
-      expectedTypes.push(expectedType || "");
-      isValid = valid;
-    }
-    if (!isValid) {
-      warn$1(getInvalidTypeMessage(name, value, expectedTypes));
-      return;
-    }
-  }
-  if (validator && !validator(value)) {
-    warn$1('Invalid prop: custom validator check failed for prop "' + name + '".');
-  }
-}
-const isSimpleType = /* @__PURE__ */ makeMap("String,Number,Boolean,Function,Symbol,BigInt");
-function assertType(value, type) {
-  let valid;
-  const expectedType = getType(type);
-  if (isSimpleType(expectedType)) {
-    const t2 = typeof value;
-    valid = t2 === expectedType.toLowerCase();
-    if (!valid && t2 === "object") {
-      valid = value instanceof type;
-    }
-  } else if (expectedType === "Object") {
-    valid = isObject$1(value);
-  } else if (expectedType === "Array") {
-    valid = isArray(value);
-  } else if (expectedType === "null") {
-    valid = value === null;
-  } else {
-    valid = value instanceof type;
-  }
-  return {
-    valid,
-    expectedType
-  };
-}
-function getInvalidTypeMessage(name, value, expectedTypes) {
-  let message = `Invalid prop: type check failed for prop "${name}". Expected ${expectedTypes.map(capitalize).join(" | ")}`;
-  const expectedType = expectedTypes[0];
-  const receivedType = toRawType(value);
-  const expectedValue = styleValue(value, expectedType);
-  const receivedValue = styleValue(value, receivedType);
-  if (expectedTypes.length === 1 && isExplicable(expectedType) && !isBoolean(expectedType, receivedType)) {
-    message += ` with value ${expectedValue}`;
-  }
-  message += `, got ${receivedType} `;
-  if (isExplicable(receivedType)) {
-    message += `with value ${receivedValue}.`;
-  }
-  return message;
-}
-function styleValue(value, type) {
-  if (type === "String") {
-    return `"${value}"`;
-  } else if (type === "Number") {
-    return `${Number(value)}`;
-  } else {
-    return `${value}`;
-  }
-}
-function isExplicable(type) {
-  const explicitTypes = ["string", "number", "boolean"];
-  return explicitTypes.some((elem) => type.toLowerCase() === elem);
-}
-function isBoolean(...args) {
-  return args.some((elem) => elem.toLowerCase() === "boolean");
-}
-function createAppContext() {
-  return {
-    app: null,
-    config: {
-      isNativeTag: NO,
-      performance: false,
-      globalProperties: {},
-      optionMergeStrategies: {},
-      errorHandler: void 0,
-      warnHandler: void 0,
-      compilerOptions: {}
-    },
-    mixins: [],
-    components: {},
-    directives: {},
-    provides: /* @__PURE__ */ Object.create(null),
-    optionsCache: /* @__PURE__ */ new WeakMap(),
-    propsCache: /* @__PURE__ */ new WeakMap(),
-    emitsCache: /* @__PURE__ */ new WeakMap()
-  };
-}
-let uid = 0;
-function createAppAPI(render, hydrate) {
-  return function createApp2(rootComponent, rootProps = null) {
-    if (!isFunction(rootComponent)) {
-      rootComponent = Object.assign({}, rootComponent);
-    }
-    if (rootProps != null && !isObject$1(rootProps)) {
-      warn$1(`root props passed to app.mount() must be an object.`);
-      rootProps = null;
-    }
-    const context = createAppContext();
-    const installedPlugins = /* @__PURE__ */ new Set();
-    const app = context.app = {
-      _uid: uid++,
-      _component: rootComponent,
-      _props: rootProps,
-      _container: null,
-      _context: context,
-      _instance: null,
-      version,
-      get config() {
-        return context.config;
-      },
-      set config(v) {
-        {
-          warn$1(`app.config cannot be replaced. Modify individual options instead.`);
-        }
-      },
-      use(plugin2, ...options) {
-        if (installedPlugins.has(plugin2)) {
-          warn$1(`Plugin has already been applied to target app.`);
-        } else if (plugin2 && isFunction(plugin2.install)) {
-          installedPlugins.add(plugin2);
-          plugin2.install(app, ...options);
-        } else if (isFunction(plugin2)) {
-          installedPlugins.add(plugin2);
-          plugin2(app, ...options);
-        } else {
-          warn$1(`A plugin must either be a function or an object with an "install" function.`);
-        }
-        return app;
-      },
-      mixin(mixin) {
-        {
-          if (!context.mixins.includes(mixin)) {
-            context.mixins.push(mixin);
-          } else {
-            warn$1("Mixin has already been applied to target app" + (mixin.name ? `: ${mixin.name}` : ""));
-          }
-        }
-        return app;
-      },
-      component(name, component) {
-        {
-          validateComponentName(name, context.config);
-        }
-        if (!component) {
-          return context.components[name];
-        }
-        if (context.components[name]) {
-          warn$1(`Component "${name}" has already been registered in target app.`);
-        }
-        context.components[name] = component;
-        return app;
-      },
-      directive(name, directive) {
-        {
-          validateDirectiveName(name);
-        }
-        if (!directive) {
-          return context.directives[name];
-        }
-        if (context.directives[name]) {
-          warn$1(`Directive "${name}" has already been registered in target app.`);
-        }
-        context.directives[name] = directive;
-        return app;
-      },
-      mount() {
-      },
-      unmount() {
-      },
-      provide(key, value) {
-        if (key in context.provides) {
-          warn$1(`App already provides property with key "${String(key)}". It will be overwritten with the new value.`);
-        }
-        context.provides[key] = value;
-        return app;
-      }
-    };
-    return app;
-  };
-}
-const queuePostRenderEffect = queuePostFlushCb;
-function isVNode(value) {
-  return value ? value.__v_isVNode === true : false;
-}
-const InternalObjectKey = `__vInternal`;
-function guardReactiveProps(props) {
-  if (!props)
-    return null;
-  return isProxy(props) || InternalObjectKey in props ? extend({}, props) : props;
-}
-const emptyAppContext = createAppContext();
-let uid$1 = 0;
-function createComponentInstance(vnode, parent, suspense) {
-  const type = vnode.type;
-  const appContext = (parent ? parent.appContext : vnode.appContext) || emptyAppContext;
-  const instance = {
-    uid: uid$1++,
-    vnode,
-    type,
-    parent,
-    appContext,
-    root: null,
-    next: null,
-    subTree: null,
-    effect: null,
-    update: null,
-    scope: new EffectScope(true),
-    render: null,
-    proxy: null,
-    exposed: null,
-    exposeProxy: null,
-    withProxy: null,
-    provides: parent ? parent.provides : Object.create(appContext.provides),
-    accessCache: null,
-    renderCache: [],
-    components: null,
-    directives: null,
-    propsOptions: normalizePropsOptions(type, appContext),
-    emitsOptions: normalizeEmitsOptions(type, appContext),
-    emit: null,
-    emitted: null,
-    propsDefaults: EMPTY_OBJ,
-    inheritAttrs: type.inheritAttrs,
-    ctx: EMPTY_OBJ,
-    data: EMPTY_OBJ,
-    props: EMPTY_OBJ,
-    attrs: EMPTY_OBJ,
-    slots: EMPTY_OBJ,
-    refs: EMPTY_OBJ,
-    setupState: EMPTY_OBJ,
-    setupContext: null,
-    suspense,
-    suspenseId: suspense ? suspense.pendingId : 0,
-    asyncDep: null,
-    asyncResolved: false,
-    isMounted: false,
-    isUnmounted: false,
-    isDeactivated: false,
-    bc: null,
-    c: null,
-    bm: null,
-    m: null,
-    bu: null,
-    u: null,
-    um: null,
-    bum: null,
-    da: null,
-    a: null,
-    rtg: null,
-    rtc: null,
-    ec: null,
-    sp: null
-  };
-  {
-    instance.ctx = createDevRenderContext(instance);
-  }
-  instance.root = parent ? parent.root : instance;
-  instance.emit = emit$1.bind(null, instance);
-  if (vnode.ce) {
-    vnode.ce(instance);
-  }
-  return instance;
-}
-let currentInstance = null;
-const getCurrentInstance = () => currentInstance || currentRenderingInstance;
-const setCurrentInstance = (instance) => {
-  currentInstance = instance;
-  instance.scope.on();
-};
-const unsetCurrentInstance = () => {
-  currentInstance && currentInstance.scope.off();
-  currentInstance = null;
-};
-const isBuiltInTag = /* @__PURE__ */ makeMap("slot,component");
-function validateComponentName(name, config) {
-  const appIsNativeTag = config.isNativeTag || NO;
-  if (isBuiltInTag(name) || appIsNativeTag(name)) {
-    warn$1("Do not use built-in or reserved HTML elements as component id: " + name);
-  }
-}
-function isStatefulComponent(instance) {
-  return instance.vnode.shapeFlag & 4;
-}
-let isInSSRComponentSetup = false;
-function setupComponent(instance, isSSR = false) {
-  isInSSRComponentSetup = isSSR;
-  const { props } = instance.vnode;
-  const isStateful = isStatefulComponent(instance);
-  initProps$1(instance, props, isStateful, isSSR);
-  const setupResult = isStateful ? setupStatefulComponent(instance, isSSR) : void 0;
-  isInSSRComponentSetup = false;
-  return setupResult;
-}
-function setupStatefulComponent(instance, isSSR) {
-  const Component2 = instance.type;
-  {
-    if (Component2.name) {
-      validateComponentName(Component2.name, instance.appContext.config);
-    }
-    if (Component2.components) {
-      const names = Object.keys(Component2.components);
-      for (let i = 0; i < names.length; i++) {
-        validateComponentName(names[i], instance.appContext.config);
-      }
-    }
-    if (Component2.directives) {
-      const names = Object.keys(Component2.directives);
-      for (let i = 0; i < names.length; i++) {
-        validateDirectiveName(names[i]);
-      }
-    }
-    if (Component2.compilerOptions && isRuntimeOnly()) {
-      warn$1(`"compilerOptions" is only supported when using a build of Vue that includes the runtime compiler. Since you are using a runtime-only build, the options should be passed via your build tool config instead.`);
-    }
-  }
-  instance.accessCache = /* @__PURE__ */ Object.create(null);
-  instance.proxy = markRaw(new Proxy(instance.ctx, PublicInstanceProxyHandlers));
-  {
-    exposePropsOnRenderContext(instance);
-  }
-  const { setup } = Component2;
-  if (setup) {
-    const setupContext = instance.setupContext = setup.length > 1 ? createSetupContext(instance) : null;
-    setCurrentInstance(instance);
-    pauseTracking();
-    const setupResult = callWithErrorHandling(setup, instance, 0, [shallowReadonly(instance.props), setupContext]);
-    resetTracking();
-    unsetCurrentInstance();
-    if (isPromise$1(setupResult)) {
-      setupResult.then(unsetCurrentInstance, unsetCurrentInstance);
-      {
-        warn$1(`setup() returned a Promise, but the version of Vue you are using does not support it yet.`);
-      }
-    } else {
-      handleSetupResult(instance, setupResult, isSSR);
-    }
-  } else {
-    finishComponentSetup(instance, isSSR);
-  }
-}
-function handleSetupResult(instance, setupResult, isSSR) {
-  if (isFunction(setupResult)) {
-    {
-      instance.render = setupResult;
-    }
-  } else if (isObject$1(setupResult)) {
-    if (isVNode(setupResult)) {
-      warn$1(`setup() should not return VNodes directly - return a render function instead.`);
-    }
-    {
-      instance.devtoolsRawSetupState = setupResult;
-    }
-    instance.setupState = proxyRefs(setupResult);
-    {
-      exposeSetupStateOnRenderContext(instance);
-    }
-  } else if (setupResult !== void 0) {
-    warn$1(`setup() should return an object. Received: ${setupResult === null ? "null" : typeof setupResult}`);
-  }
-  finishComponentSetup(instance, isSSR);
-}
-let compile;
-const isRuntimeOnly = () => !compile;
-function finishComponentSetup(instance, isSSR, skipOptions) {
-  const Component2 = instance.type;
-  if (!instance.render) {
-    instance.render = Component2.render || NOOP;
-  }
-  {
-    setCurrentInstance(instance);
-    pauseTracking();
-    applyOptions$1(instance);
-    resetTracking();
-    unsetCurrentInstance();
-  }
-  if (!Component2.render && instance.render === NOOP && !isSSR) {
-    if (Component2.template) {
-      warn$1(`Component provided template option but runtime compilation is not supported in this build of Vue. Configure your bundler to alias "vue" to "vue/dist/vue.esm-bundler.js".`);
-    } else {
-      warn$1(`Component is missing template or render function.`);
-    }
-  }
-}
-function createAttrsProxy(instance) {
-  return new Proxy(instance.attrs, {
-    get(target, key) {
-      track(instance, "get", "$attrs");
-      return target[key];
-    },
-    set() {
-      warn$1(`setupContext.attrs is readonly.`);
-      return false;
-    },
-    deleteProperty() {
-      warn$1(`setupContext.attrs is readonly.`);
-      return false;
-    }
-  });
-}
-function createSetupContext(instance) {
-  const expose = (exposed) => {
-    if (instance.exposed) {
-      warn$1(`expose() should be called only once per setup().`);
-    }
-    instance.exposed = exposed || {};
-  };
-  let attrs;
-  {
-    return Object.freeze({
-      get attrs() {
-        return attrs || (attrs = createAttrsProxy(instance));
-      },
-      get slots() {
-        return shallowReadonly(instance.slots);
-      },
-      get emit() {
-        return (event, ...args) => instance.emit(event, ...args);
-      },
-      expose
-    });
-  }
-}
-function getExposeProxy(instance) {
-  if (instance.exposed) {
-    return instance.exposeProxy || (instance.exposeProxy = new Proxy(proxyRefs(markRaw(instance.exposed)), {
-      get(target, key) {
-        if (key in target) {
-          return target[key];
-        }
-        return instance.proxy[key];
-      }
-    }));
-  }
-}
-const classifyRE = /(?:^|[-_])(\w)/g;
-const classify = (str) => str.replace(classifyRE, (c) => c.toUpperCase()).replace(/[-_]/g, "");
-function getComponentName(Component2, includeInferred = true) {
-  return isFunction(Component2) ? Component2.displayName || Component2.name : Component2.name || includeInferred && Component2.__name;
-}
-function formatComponentName(instance, Component2, isRoot = false) {
-  let name = getComponentName(Component2);
-  if (!name && Component2.__file) {
-    const match = Component2.__file.match(/([^/\\]+)\.\w+$/);
-    if (match) {
-      name = match[1];
-    }
-  }
-  if (!name && instance && instance.parent) {
-    const inferFromRegistry = (registry) => {
-      for (const key in registry) {
-        if (registry[key] === Component2) {
-          return key;
-        }
-      }
-    };
-    name = inferFromRegistry(instance.components || instance.parent.type.components) || inferFromRegistry(instance.appContext.components);
-  }
-  return name ? classify(name) : isRoot ? `App` : `Anonymous`;
-}
-const computed$1 = (getterOrOptions, debugOptions) => {
-  return computed(getterOrOptions, debugOptions, isInSSRComponentSetup);
-};
-const version = "3.2.37";
-function unwrapper(target) {
-  return unref(target);
-}
-const ARRAYTYPE = "[object Array]";
-const OBJECTTYPE = "[object Object]";
-function diff(current, pre) {
-  const result = {};
-  syncKeys(current, pre);
-  _diff(current, pre, "", result);
-  return result;
-}
-function syncKeys(current, pre) {
-  current = unwrapper(current);
-  if (current === pre)
-    return;
-  const rootCurrentType = toTypeString(current);
-  const rootPreType = toTypeString(pre);
-  if (rootCurrentType == OBJECTTYPE && rootPreType == OBJECTTYPE) {
-    for (let key in pre) {
-      const currentValue = current[key];
-      if (currentValue === void 0) {
-        current[key] = null;
-      } else {
-        syncKeys(currentValue, pre[key]);
-      }
-    }
-  } else if (rootCurrentType == ARRAYTYPE && rootPreType == ARRAYTYPE) {
-    if (current.length >= pre.length) {
-      pre.forEach((item, index2) => {
-        syncKeys(current[index2], item);
-      });
-    }
-  }
-}
-function _diff(current, pre, path, result) {
-  current = unwrapper(current);
-  if (current === pre)
-    return;
-  const rootCurrentType = toTypeString(current);
-  const rootPreType = toTypeString(pre);
-  if (rootCurrentType == OBJECTTYPE) {
-    if (rootPreType != OBJECTTYPE || Object.keys(current).length < Object.keys(pre).length) {
-      setResult(result, path, current);
-    } else {
-      for (let key in current) {
-        const currentValue = unwrapper(current[key]);
-        const preValue = pre[key];
-        const currentType = toTypeString(currentValue);
-        const preType = toTypeString(preValue);
-        if (currentType != ARRAYTYPE && currentType != OBJECTTYPE) {
-          if (currentValue != preValue) {
-            setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
-          }
-        } else if (currentType == ARRAYTYPE) {
-          if (preType != ARRAYTYPE) {
-            setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
-          } else {
-            if (currentValue.length < preValue.length) {
-              setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
-            } else {
-              currentValue.forEach((item, index2) => {
-                _diff(item, preValue[index2], (path == "" ? "" : path + ".") + key + "[" + index2 + "]", result);
-              });
-            }
-          }
-        } else if (currentType == OBJECTTYPE) {
-          if (preType != OBJECTTYPE || Object.keys(currentValue).length < Object.keys(preValue).length) {
-            setResult(result, (path == "" ? "" : path + ".") + key, currentValue);
-          } else {
-            for (let subKey in currentValue) {
-              _diff(currentValue[subKey], preValue[subKey], (path == "" ? "" : path + ".") + key + "." + subKey, result);
-            }
-          }
-        }
-      }
-    }
-  } else if (rootCurrentType == ARRAYTYPE) {
-    if (rootPreType != ARRAYTYPE) {
-      setResult(result, path, current);
-    } else {
-      if (current.length < pre.length) {
-        setResult(result, path, current);
-      } else {
-        current.forEach((item, index2) => {
-          _diff(item, pre[index2], path + "[" + index2 + "]", result);
-        });
-      }
-    }
-  } else {
-    setResult(result, path, current);
-  }
-}
-function setResult(result, k, v) {
-  result[k] = v;
-}
-function hasComponentEffect(instance) {
-  return queue.includes(instance.update);
-}
-function flushCallbacks(instance) {
-  const ctx = instance.ctx;
-  const callbacks = ctx.__next_tick_callbacks;
-  if (callbacks && callbacks.length) {
-    const copies = callbacks.slice(0);
-    callbacks.length = 0;
-    for (let i = 0; i < copies.length; i++) {
-      copies[i]();
-    }
-  }
-}
-function nextTick$1(instance, fn) {
-  const ctx = instance.ctx;
-  if (!ctx.__next_tick_pending && !hasComponentEffect(instance)) {
-    return nextTick(fn && fn.bind(instance.proxy));
-  }
-  let _resolve;
-  if (!ctx.__next_tick_callbacks) {
-    ctx.__next_tick_callbacks = [];
-  }
-  ctx.__next_tick_callbacks.push(() => {
-    if (fn) {
-      callWithErrorHandling(fn.bind(instance.proxy), instance, 14);
-    } else if (_resolve) {
-      _resolve(instance.proxy);
-    }
-  });
-  return new Promise((resolve2) => {
-    _resolve = resolve2;
-  });
-}
-function clone(src, seen) {
-  src = unwrapper(src);
-  const type = typeof src;
-  if (type === "object" && src !== null) {
-    let copy = seen.get(src);
-    if (typeof copy !== "undefined") {
-      return copy;
-    }
-    if (isArray(src)) {
-      const len = src.length;
-      copy = new Array(len);
-      seen.set(src, copy);
-      for (let i = 0; i < len; i++) {
-        copy[i] = clone(src[i], seen);
-      }
-    } else {
-      copy = {};
-      seen.set(src, copy);
-      for (const name in src) {
-        if (hasOwn(src, name)) {
-          copy[name] = clone(src[name], seen);
-        }
-      }
-    }
-    return copy;
-  }
-  if (type !== "symbol") {
-    return src;
-  }
-}
-function deepCopy(src) {
-  return clone(src, typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : /* @__PURE__ */ new Map());
-}
-function getMPInstanceData(instance, keys) {
-  const data = instance.data;
-  const ret = /* @__PURE__ */ Object.create(null);
-  keys.forEach((key) => {
-    ret[key] = data[key];
-  });
-  return ret;
-}
-function patch(instance, data, oldData) {
-  if (!data) {
-    return;
-  }
-  data = deepCopy(data);
-  const ctx = instance.ctx;
-  const mpType = ctx.mpType;
-  if (mpType === "page" || mpType === "component") {
-    data.r0 = 1;
-    const mpInstance = ctx.$scope;
-    const keys = Object.keys(data);
-    const diffData = diff(data, oldData || getMPInstanceData(mpInstance, keys));
-    if (Object.keys(diffData).length) {
-      ctx.__next_tick_pending = true;
-      mpInstance.setData(diffData, () => {
-        ctx.__next_tick_pending = false;
-        flushCallbacks(instance);
-      });
-      flushPreFlushCbs(void 0, instance.update);
-    } else {
-      flushCallbacks(instance);
-    }
-  }
-}
-function initAppConfig(appConfig) {
-  appConfig.globalProperties.$nextTick = function $nextTick(fn) {
-    return nextTick$1(this.$, fn);
-  };
-}
-function onApplyOptions(options, instance, publicThis) {
-  instance.appContext.config.globalProperties.$applyOptions(options, instance, publicThis);
-  const computedOptions = options.computed;
-  if (computedOptions) {
-    const keys = Object.keys(computedOptions);
-    if (keys.length) {
-      const ctx = instance.ctx;
-      if (!ctx.$computedKeys) {
-        ctx.$computedKeys = [];
-      }
-      ctx.$computedKeys.push(...keys);
-    }
-  }
-  delete instance.ctx.$onApplyOptions;
-}
-function setRef$1(instance, isUnmount = false) {
-  const { setupState, $templateRefs, ctx: { $scope, $mpPlatform } } = instance;
-  if ($mpPlatform === "mp-alipay") {
-    return;
-  }
-  if (!$templateRefs || !$scope) {
-    return;
-  }
-  if (isUnmount) {
-    return $templateRefs.forEach((templateRef) => setTemplateRef(templateRef, null, setupState));
-  }
-  const check = $mpPlatform === "mp-baidu" || $mpPlatform === "mp-toutiao";
-  const doSetByRefs = (refs) => {
-    const mpComponents = $scope.selectAllComponents(".r").concat($scope.selectAllComponents(".r-i-f"));
-    return refs.filter((templateRef) => {
-      const refValue = findComponentPublicInstance(mpComponents, templateRef.i);
-      if (check && refValue === null) {
-        return true;
-      }
-      setTemplateRef(templateRef, refValue, setupState);
-      return false;
-    });
-  };
-  const doSet = () => {
-    const refs = doSetByRefs($templateRefs);
-    if (refs.length && instance.proxy && instance.proxy.$scope) {
-      instance.proxy.$scope.setData({ r1: 1 }, () => {
-        doSetByRefs(refs);
-      });
-    }
-  };
-  if ($scope._$setRef) {
-    $scope._$setRef(doSet);
-  } else {
-    nextTick$1(instance, doSet);
-  }
-}
-function findComponentPublicInstance(mpComponents, id) {
-  const mpInstance = mpComponents.find((com) => com && (com.properties || com.props).uI === id);
-  if (mpInstance) {
-    const vm = mpInstance.$vm;
-    if (vm) {
-      return getExposeProxy(vm.$) || vm;
-    }
-    return mpInstance;
-  }
-  return null;
-}
-function setTemplateRef({ r, f: f2 }, refValue, setupState) {
-  if (isFunction(r)) {
-    r(refValue, {});
-  } else {
-    const _isString = isString(r);
-    const _isRef = isRef(r);
-    if (_isString || _isRef) {
-      if (f2) {
-        if (!_isRef) {
-          return;
-        }
-        if (!isArray(r.value)) {
-          r.value = [];
-        }
-        const existing = r.value;
-        if (existing.indexOf(refValue) === -1) {
-          existing.push(refValue);
-          if (!refValue) {
-            return;
-          }
-          onBeforeUnmount(() => remove(existing, refValue), refValue.$);
-        }
-      } else if (_isString) {
-        if (hasOwn(setupState, r)) {
-          setupState[r] = refValue;
-        }
-      } else if (isRef(r)) {
-        r.value = refValue;
-      } else {
-        warnRef(r);
-      }
-    } else {
-      warnRef(r);
-    }
-  }
-}
-function warnRef(ref2) {
-  warn$1("Invalid template ref type:", ref2, `(${typeof ref2})`);
-}
-var MPType;
-(function(MPType2) {
-  MPType2["APP"] = "app";
-  MPType2["PAGE"] = "page";
-  MPType2["COMPONENT"] = "component";
-})(MPType || (MPType = {}));
-const queuePostRenderEffect$1 = queuePostFlushCb;
-function mountComponent(initialVNode, options) {
-  const instance = initialVNode.component = createComponentInstance(initialVNode, options.parentComponent, null);
-  {
-    instance.ctx.$onApplyOptions = onApplyOptions;
-    instance.ctx.$children = [];
-  }
-  if (options.mpType === "app") {
-    instance.render = NOOP;
-  }
-  if (options.onBeforeSetup) {
-    options.onBeforeSetup(instance, options);
-  }
-  {
-    pushWarningContext(initialVNode);
-  }
-  setupComponent(instance);
-  {
-    if (options.parentComponent && instance.proxy) {
-      options.parentComponent.ctx.$children.push(getExposeProxy(instance) || instance.proxy);
-    }
-  }
-  setupRenderEffect(instance);
-  {
-    popWarningContext();
-  }
-  return instance.proxy;
-}
-const getFunctionalFallthrough = (attrs) => {
-  let res;
-  for (const key in attrs) {
-    if (key === "class" || key === "style" || isOn(key)) {
-      (res || (res = {}))[key] = attrs[key];
-    }
-  }
-  return res;
-};
-function renderComponentRoot(instance) {
-  const { type: Component2, vnode, proxy, withProxy, props, propsOptions: [propsOptions], slots, attrs, emit: emit2, render, renderCache, data, setupState, ctx, uid: uid2, appContext: { app: { config: { globalProperties: { pruneComponentPropsCache: pruneComponentPropsCache2 } } } }, inheritAttrs } = instance;
-  instance.$templateRefs = [];
-  instance.$ei = 0;
-  pruneComponentPropsCache2(uid2);
-  instance.__counter = instance.__counter === 0 ? 1 : 0;
-  let result;
-  const prev = setCurrentRenderingInstance(instance);
-  try {
-    if (vnode.shapeFlag & 4) {
-      fallthroughAttrs(inheritAttrs, props, propsOptions, attrs);
-      const proxyToUse = withProxy || proxy;
-      result = render.call(proxyToUse, proxyToUse, renderCache, props, setupState, data, ctx);
-    } else {
-      fallthroughAttrs(inheritAttrs, props, propsOptions, Component2.props ? attrs : getFunctionalFallthrough(attrs));
-      const render2 = Component2;
-      result = render2.length > 1 ? render2(props, { attrs, slots, emit: emit2 }) : render2(props, null);
-    }
-  } catch (err) {
-    handleError(err, instance, 1);
-    result = false;
-  }
-  setRef$1(instance);
-  setCurrentRenderingInstance(prev);
-  return result;
-}
-function fallthroughAttrs(inheritAttrs, props, propsOptions, fallthroughAttrs2) {
-  if (props && fallthroughAttrs2 && inheritAttrs !== false) {
-    const keys = Object.keys(fallthroughAttrs2).filter((key) => key !== "class" && key !== "style");
-    if (!keys.length) {
-      return;
-    }
-    if (propsOptions && keys.some(isModelListener)) {
-      keys.forEach((key) => {
-        if (!isModelListener(key) || !(key.slice(9) in propsOptions)) {
-          props[key] = fallthroughAttrs2[key];
-        }
-      });
-    } else {
-      keys.forEach((key) => props[key] = fallthroughAttrs2[key]);
-    }
-  }
-}
-const updateComponentPreRender = (instance) => {
-  pauseTracking();
-  flushPreFlushCbs(void 0, instance.update);
-  resetTracking();
-};
-function componentUpdateScopedSlotsFn() {
-  const scopedSlotsData = this.$scopedSlotsData;
-  if (!scopedSlotsData || scopedSlotsData.length === 0) {
-    return;
-  }
-  const mpInstance = this.ctx.$scope;
-  const oldData = mpInstance.data;
-  const diffData = /* @__PURE__ */ Object.create(null);
-  scopedSlotsData.forEach(({ path, index: index2, data }) => {
-    const oldScopedSlotData = getValueByDataPath(oldData, path);
-    const diffPath = isString(index2) ? `${path}.${index2}` : `${path}[${index2}]`;
-    if (typeof oldScopedSlotData === "undefined" || typeof oldScopedSlotData[index2] === "undefined") {
-      diffData[diffPath] = data;
-    } else {
-      const diffScopedSlotData = diff(data, oldScopedSlotData[index2]);
-      Object.keys(diffScopedSlotData).forEach((name) => {
-        diffData[diffPath + "." + name] = diffScopedSlotData[name];
-      });
-    }
-  });
-  scopedSlotsData.length = 0;
-  if (Object.keys(diffData).length) {
-    mpInstance.setData(diffData);
-  }
-}
-function toggleRecurse({ effect, update: update3 }, allowed) {
-  effect.allowRecurse = update3.allowRecurse = allowed;
-}
-function setupRenderEffect(instance) {
-  const updateScopedSlots = componentUpdateScopedSlotsFn.bind(instance);
-  instance.$updateScopedSlots = () => nextTick(() => queueJob(updateScopedSlots));
-  const componentUpdateFn = () => {
-    if (!instance.isMounted) {
-      onBeforeUnmount(() => {
-        setRef$1(instance, true);
-      }, instance);
-      patch(instance, renderComponentRoot(instance));
-    } else {
-      const { bu, u } = instance;
-      toggleRecurse(instance, false);
-      updateComponentPreRender(instance);
-      if (bu) {
-        invokeArrayFns$1(bu);
-      }
-      toggleRecurse(instance, true);
-      patch(instance, renderComponentRoot(instance));
-      if (u) {
-        queuePostRenderEffect$1(u);
-      }
-    }
-  };
-  const effect = instance.effect = new ReactiveEffect(componentUpdateFn, () => queueJob(instance.update), instance.scope);
-  const update3 = instance.update = effect.run.bind(effect);
-  update3.id = instance.uid;
-  toggleRecurse(instance, true);
-  {
-    effect.onTrack = instance.rtc ? (e2) => invokeArrayFns$1(instance.rtc, e2) : void 0;
-    effect.onTrigger = instance.rtg ? (e2) => invokeArrayFns$1(instance.rtg, e2) : void 0;
-    update3.ownerInstance = instance;
-  }
-  update3();
-}
-function unmountComponent(instance) {
-  const { bum, scope, update: update3, um } = instance;
-  if (bum) {
-    invokeArrayFns$1(bum);
-  }
-  scope.stop();
-  if (update3) {
-    update3.active = false;
-  }
-  if (um) {
-    queuePostRenderEffect$1(um);
-  }
-  queuePostRenderEffect$1(() => {
-    instance.isUnmounted = true;
-  });
-}
-const oldCreateApp = createAppAPI();
-function createVueApp(rootComponent, rootProps = null) {
-  const app = oldCreateApp(rootComponent, rootProps);
-  const appContext = app._context;
-  initAppConfig(appContext.config);
-  const createVNode = (initialVNode) => {
-    initialVNode.appContext = appContext;
-    initialVNode.shapeFlag = 6;
-    return initialVNode;
-  };
-  const createComponent2 = function createComponent3(initialVNode, options) {
-    return mountComponent(createVNode(initialVNode), options);
-  };
-  const destroyComponent = function destroyComponent2(component) {
-    return component && unmountComponent(component.$);
-  };
-  app.mount = function mount() {
-    rootComponent.render = NOOP;
-    const instance = mountComponent(createVNode({ type: rootComponent }), {
-      mpType: MPType.APP,
-      mpInstance: null,
-      parentComponent: null,
-      slots: [],
-      props: null
-    });
-    app._instance = instance.$;
-    instance.$app = app;
-    instance.$createComponent = createComponent2;
-    instance.$destroyComponent = destroyComponent;
-    appContext.$appInstance = instance;
-    return instance;
-  };
-  app.unmount = function unmount() {
-    warn$1(`Cannot unmount an app.`);
-  };
-  return app;
-}
-function injectLifecycleHook(name, hook, publicThis, instance) {
-  if (isFunction(hook)) {
-    injectHook(name, hook.bind(publicThis), instance);
-  }
-}
-function initHooks$1(options, instance, publicThis) {
-  const mpType = options.mpType || publicThis.$mpType;
-  if (!mpType) {
-    return;
-  }
-  Object.keys(options).forEach((name) => {
-    if (name.indexOf("on") === 0) {
-      const hooks = options[name];
-      if (isArray(hooks)) {
-        hooks.forEach((hook) => injectLifecycleHook(name, hook, publicThis, instance));
-      } else {
-        injectLifecycleHook(name, hooks, publicThis, instance);
-      }
-    }
-  });
-}
-function applyOptions$2(options, instance, publicThis) {
-  initHooks$1(options, instance, publicThis);
-}
-function set(target, key, val) {
-  return target[key] = val;
-}
-function createErrorHandler(app) {
-  return function errorHandler(err, instance, _info) {
-    if (!instance) {
-      throw err;
-    }
-    const appInstance = app._instance;
-    if (!appInstance || !appInstance.proxy) {
-      throw err;
-    }
-    {
-      appInstance.proxy.$callHook(ON_ERROR, err);
-    }
-  };
-}
-function mergeAsArray(to, from) {
-  return to ? [...new Set([].concat(to, from))] : from;
-}
-function initOptionMergeStrategies(optionMergeStrategies) {
-  UniLifecycleHooks.forEach((name) => {
-    optionMergeStrategies[name] = mergeAsArray;
-  });
-}
-let realAtob;
-const b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
-const b64re = /^(?:[A-Za-z\d+/]{4})*?(?:[A-Za-z\d+/]{2}(?:==)?|[A-Za-z\d+/]{3}=?)?$/;
-if (typeof atob !== "function") {
-  realAtob = function(str) {
-    str = String(str).replace(/[\t\n\f\r ]+/g, "");
-    if (!b64re.test(str)) {
-      throw new Error("Failed to execute 'atob' on 'Window': The string to be decoded is not correctly encoded.");
-    }
-    str += "==".slice(2 - (str.length & 3));
-    var bitmap;
-    var result = "";
-    var r1;
-    var r2;
-    var i = 0;
-    for (; i < str.length; ) {
-      bitmap = b64.indexOf(str.charAt(i++)) << 18 | b64.indexOf(str.charAt(i++)) << 12 | (r1 = b64.indexOf(str.charAt(i++))) << 6 | (r2 = b64.indexOf(str.charAt(i++)));
-      result += r1 === 64 ? String.fromCharCode(bitmap >> 16 & 255) : r2 === 64 ? String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255) : String.fromCharCode(bitmap >> 16 & 255, bitmap >> 8 & 255, bitmap & 255);
-    }
-    return result;
-  };
-} else {
-  realAtob = atob;
-}
-function b64DecodeUnicode(str) {
-  return decodeURIComponent(realAtob(str).split("").map(function(c) {
-    return "%" + ("00" + c.charCodeAt(0).toString(16)).slice(-2);
-  }).join(""));
-}
-function getCurrentUserInfo() {
-  const token = index.getStorageSync("uni_id_token") || "";
-  const tokenArr = token.split(".");
-  if (!token || tokenArr.length !== 3) {
-    return {
-      uid: null,
-      role: [],
-      permission: [],
-      tokenExpired: 0
-    };
-  }
-  let userInfo;
-  try {
-    userInfo = JSON.parse(b64DecodeUnicode(tokenArr[1]));
-  } catch (error) {
-    throw new Error("\u83B7\u53D6\u5F53\u524D\u7528\u6237\u4FE1\u606F\u51FA\u9519\uFF0C\u8BE6\u7EC6\u9519\u8BEF\u4FE1\u606F\u4E3A\uFF1A" + error.message);
-  }
-  userInfo.tokenExpired = userInfo.exp * 1e3;
-  delete userInfo.exp;
-  delete userInfo.iat;
-  return userInfo;
-}
-function uniIdMixin(globalProperties) {
-  globalProperties.uniIDHasRole = function(roleId) {
-    const { role } = getCurrentUserInfo();
-    return role.indexOf(roleId) > -1;
-  };
-  globalProperties.uniIDHasPermission = function(permissionId) {
-    const { permission } = getCurrentUserInfo();
-    return this.uniIDHasRole("admin") || permission.indexOf(permissionId) > -1;
-  };
-  globalProperties.uniIDTokenValid = function() {
-    const { tokenExpired } = getCurrentUserInfo();
-    return tokenExpired > Date.now();
-  };
-}
-function initApp(app) {
-  const appConfig = app._context.config;
-  if (isFunction(app._component.onError)) {
-    appConfig.errorHandler = createErrorHandler(app);
-  }
-  initOptionMergeStrategies(appConfig.optionMergeStrategies);
-  const globalProperties = appConfig.globalProperties;
-  {
-    uniIdMixin(globalProperties);
-  }
-  {
-    globalProperties.$set = set;
-    globalProperties.$applyOptions = applyOptions$2;
-  }
-  {
-    index.invokeCreateVueAppHook(app);
-  }
-}
-const propsCaches = /* @__PURE__ */ Object.create(null);
-function renderProps(props) {
-  const { uid: uid2, __counter } = getCurrentInstance();
-  const propsId = (propsCaches[uid2] || (propsCaches[uid2] = [])).push(guardReactiveProps(props)) - 1;
-  return uid2 + "," + propsId + "," + __counter;
-}
-function pruneComponentPropsCache(uid2) {
-  delete propsCaches[uid2];
-}
-function findComponentPropsData(up) {
-  if (!up) {
-    return;
-  }
-  const [uid2, propsId] = up.split(",");
-  if (!propsCaches[uid2]) {
-    return;
-  }
-  return propsCaches[uid2][parseInt(propsId)];
-}
-var plugin = {
-  install(app) {
-    initApp(app);
-    app.config.globalProperties.pruneComponentPropsCache = pruneComponentPropsCache;
-    const oldMount = app.mount;
-    app.mount = function mount(rootContainer) {
-      const instance = oldMount.call(app, rootContainer);
-      const createApp2 = getCreateApp();
-      if (createApp2) {
-        createApp2(instance);
-      } else {
-        if (typeof createMiniProgramApp !== "undefined") {
-          createMiniProgramApp(instance);
-        }
-      }
-      return instance;
-    };
-  }
-};
-function getCreateApp() {
-  const method = "createApp";
-  if (typeof global !== "undefined") {
-    return global[method];
-  } else if (typeof my !== "undefined") {
-    return my[method];
-  }
-}
-function vOn(value, key) {
-  const instance = getCurrentInstance();
-  const ctx = instance.ctx;
-  const extraKey = typeof key !== "undefined" && (ctx.$mpPlatform === "mp-weixin" || ctx.$mpPlatform === "mp-qq") && (isString(key) || typeof key === "number") ? "_" + key : "";
-  const name = "e" + instance.$ei++ + extraKey;
-  const mpInstance = ctx.$scope;
-  if (!value) {
-    delete mpInstance[name];
-    return name;
-  }
-  const existingInvoker = mpInstance[name];
-  if (existingInvoker) {
-    existingInvoker.value = value;
-  } else {
-    mpInstance[name] = createInvoker(value, instance);
-  }
-  return name;
-}
-function createInvoker(initialValue, instance) {
-  const invoker = (e2) => {
-    patchMPEvent(e2);
-    let args = [e2];
-    if (e2.detail && e2.detail.__args__) {
-      args = e2.detail.__args__;
-    }
-    const eventValue = invoker.value;
-    const invoke = () => callWithAsyncErrorHandling(patchStopImmediatePropagation(e2, eventValue), instance, 5, args);
-    const eventTarget = e2.target;
-    const eventSync = eventTarget ? eventTarget.dataset ? eventTarget.dataset.eventsync === "true" : false : false;
-    if (bubbles.includes(e2.type) && !eventSync) {
-      setTimeout(invoke);
-    } else {
-      const res = invoke();
-      if (e2.type === "input" && (isArray(res) || isPromise$1(res))) {
-        return;
-      }
-      return res;
-    }
-  };
-  invoker.value = initialValue;
-  return invoker;
-}
-const bubbles = [
-  "tap",
-  "longpress",
-  "longtap",
-  "transitionend",
-  "animationstart",
-  "animationiteration",
-  "animationend",
-  "touchforcechange"
-];
-function patchMPEvent(event) {
-  if (event.type && event.target) {
-    event.preventDefault = NOOP;
-    event.stopPropagation = NOOP;
-    event.stopImmediatePropagation = NOOP;
-    if (!hasOwn(event, "detail")) {
-      event.detail = {};
-    }
-    if (hasOwn(event, "markerId")) {
-      event.detail = typeof event.detail === "object" ? event.detail : {};
-      event.detail.markerId = event.markerId;
-    }
-    if (isPlainObject(event.detail) && hasOwn(event.detail, "checked") && !hasOwn(event.detail, "value")) {
-      event.detail.value = event.detail.checked;
-    }
-    if (isPlainObject(event.detail)) {
-      event.target = extend({}, event.target, event.detail);
-    }
-  }
-}
-function patchStopImmediatePropagation(e2, value) {
-  if (isArray(value)) {
-    const originalStop = e2.stopImmediatePropagation;
-    e2.stopImmediatePropagation = () => {
-      originalStop && originalStop.call(e2);
-      e2._stopped = true;
-    };
-    return value.map((fn) => (e3) => !e3._stopped && fn(e3));
-  } else {
-    return value;
-  }
-}
-function vFor(source, renderItem) {
-  let ret;
-  if (isArray(source) || isString(source)) {
-    ret = new Array(source.length);
-    for (let i = 0, l = source.length; i < l; i++) {
-      ret[i] = renderItem(source[i], i, i);
-    }
-  } else if (typeof source === "number") {
-    if (!Number.isInteger(source)) {
-      warn$1(`The v-for range expect an integer value but got ${source}.`);
-      return [];
-    }
-    ret = new Array(source);
-    for (let i = 0; i < source; i++) {
-      ret[i] = renderItem(i + 1, i, i);
-    }
-  } else if (isObject$1(source)) {
-    if (source[Symbol.iterator]) {
-      ret = Array.from(source, (item, i) => renderItem(item, i, i));
-    } else {
-      const keys = Object.keys(source);
-      ret = new Array(keys.length);
-      for (let i = 0, l = keys.length; i < l; i++) {
-        const key = keys[i];
-        ret[i] = renderItem(source[key], key, i);
-      }
-    }
-  } else {
-    ret = [];
-  }
-  return ret;
-}
-function stringifyStyle(value) {
-  if (isString(value)) {
-    return value;
-  }
-  return stringify(normalizeStyle(value));
-}
-function stringify(styles) {
-  let ret = "";
-  if (!styles || isString(styles)) {
-    return ret;
-  }
-  for (const key in styles) {
-    ret += `${key.startsWith(`--`) ? key : hyphenate(key)}:${styles[key]};`;
-  }
-  return ret;
-}
-function setRef(ref2, id, opts = {}) {
-  const { $templateRefs } = getCurrentInstance();
-  $templateRefs.push({ i: id, r: ref2, k: opts.k, f: opts.f });
-}
-const o = (value, key) => vOn(value, key);
-const f = (source, renderItem) => vFor(source, renderItem);
-const s = (value) => stringifyStyle(value);
-const e = (target, ...sources) => extend(target, ...sources);
-const n = (value) => normalizeClass(value);
-const t = (val) => toDisplayString(val);
-const p = (props) => renderProps(props);
-const sr = (ref2, id, opts) => setRef(ref2, id, opts);
-function createApp$1(rootComponent, rootProps = null) {
-  rootComponent && (rootComponent.mpType = "app");
-  return createVueApp(rootComponent, rootProps).use(plugin);
-}
-const createSSRApp = createApp$1;
-const eventChannels = {};
-const eventChannelStack = [];
-function getEventChannel(id) {
-  if (id) {
-    const eventChannel = eventChannels[id];
-    delete eventChannels[id];
-    return eventChannel;
-  }
-  return eventChannelStack.shift();
-}
-const MP_METHODS = [
-  "createSelectorQuery",
-  "createIntersectionObserver",
-  "selectAllComponents",
-  "selectComponent"
-];
-function createEmitFn(oldEmit, ctx) {
-  return function emit2(event, ...args) {
-    const scope = ctx.$scope;
-    if (scope && event) {
-      const detail = { __args__: args };
-      {
-        scope.triggerEvent(event, detail);
-      }
-    }
-    return oldEmit.apply(this, [event, ...args]);
-  };
-}
-function initBaseInstance(instance, options) {
-  const ctx = instance.ctx;
-  ctx.mpType = options.mpType;
-  ctx.$mpType = options.mpType;
-  ctx.$mpPlatform = "mp-weixin";
-  ctx.$scope = options.mpInstance;
-  ctx.$mp = {};
-  {
-    ctx._self = {};
-  }
-  instance.slots = {};
-  if (isArray(options.slots) && options.slots.length) {
-    options.slots.forEach((name) => {
-      instance.slots[name] = true;
-    });
-    if (instance.slots[SLOT_DEFAULT_NAME]) {
-      instance.slots.default = true;
-    }
-  }
-  ctx.getOpenerEventChannel = function() {
-    {
-      return options.mpInstance.getOpenerEventChannel();
-    }
-  };
-  ctx.$hasHook = hasHook;
-  ctx.$callHook = callHook;
-  instance.emit = createEmitFn(instance.emit, ctx);
-}
-function initComponentInstance(instance, options) {
-  initBaseInstance(instance, options);
-  const ctx = instance.ctx;
-  MP_METHODS.forEach((method) => {
-    ctx[method] = function(...args) {
-      const mpInstance = ctx.$scope;
-      if (mpInstance && mpInstance[method]) {
-        return mpInstance[method].apply(mpInstance, args);
-      }
-    };
-  });
-}
-function initMocks(instance, mpInstance, mocks2) {
-  const ctx = instance.ctx;
-  mocks2.forEach((mock) => {
-    if (hasOwn(mpInstance, mock)) {
-      instance[mock] = ctx[mock] = mpInstance[mock];
-    }
-  });
-}
-function hasHook(name) {
-  const hooks = this.$[name];
-  if (hooks && hooks.length) {
-    return true;
-  }
-  return false;
-}
-function callHook(name, args) {
-  if (name === "mounted") {
-    callHook.call(this, "bm");
-    this.$.isMounted = true;
-    name = "m";
-  } else if (name === "onLoad" && args && args.__id__) {
-    this.__eventChannel__ = getEventChannel(args.__id__);
-    delete args.__id__;
-  }
-  const hooks = this.$[name];
-  return hooks && invokeArrayFns(hooks, args);
-}
-const PAGE_INIT_HOOKS = [
-  ON_LOAD,
-  ON_SHOW,
-  ON_HIDE,
-  ON_UNLOAD,
-  ON_RESIZE,
-  ON_TAB_ITEM_TAP,
-  ON_REACH_BOTTOM,
-  ON_PULL_DOWN_REFRESH,
-  ON_ADD_TO_FAVORITES
-];
-function findHooks(vueOptions, hooks = /* @__PURE__ */ new Set()) {
-  if (vueOptions) {
-    Object.keys(vueOptions).forEach((name) => {
-      if (name.indexOf("on") === 0 && isFunction(vueOptions[name])) {
-        hooks.add(name);
-      }
-    });
-    {
-      const { extends: extendsOptions, mixins } = vueOptions;
-      if (mixins) {
-        mixins.forEach((mixin) => findHooks(mixin, hooks));
-      }
-      if (extendsOptions) {
-        findHooks(extendsOptions, hooks);
-      }
-    }
-  }
-  return hooks;
-}
-function initHook(mpOptions, hook, excludes) {
-  if (excludes.indexOf(hook) === -1 && !hasOwn(mpOptions, hook)) {
-    mpOptions[hook] = function(args) {
-      return this.$vm && this.$vm.$callHook(hook, args);
-    };
-  }
-}
-const EXCLUDE_HOOKS = [ON_READY];
-function initHooks(mpOptions, hooks, excludes = EXCLUDE_HOOKS) {
-  hooks.forEach((hook) => initHook(mpOptions, hook, excludes));
-}
-function initUnknownHooks(mpOptions, vueOptions, excludes = EXCLUDE_HOOKS) {
-  findHooks(vueOptions).forEach((hook) => initHook(mpOptions, hook, excludes));
-}
-function initRuntimeHooks(mpOptions, runtimeHooks) {
-  if (!runtimeHooks) {
-    return;
-  }
-  const hooks = Object.keys(MINI_PROGRAM_PAGE_RUNTIME_HOOKS);
-  hooks.forEach((hook) => {
-    if (runtimeHooks & MINI_PROGRAM_PAGE_RUNTIME_HOOKS[hook]) {
-      initHook(mpOptions, hook, []);
-    }
-  });
-}
-const findMixinRuntimeHooks = /* @__PURE__ */ once(() => {
-  const runtimeHooks = [];
-  const app = getApp({ allowDefault: true });
-  if (app && app.$vm && app.$vm.$) {
-    const mixins = app.$vm.$.appContext.mixins;
-    if (isArray(mixins)) {
-      const hooks = Object.keys(MINI_PROGRAM_PAGE_RUNTIME_HOOKS);
-      mixins.forEach((mixin) => {
-        hooks.forEach((hook) => {
-          if (hasOwn(mixin, hook) && !runtimeHooks.includes(hook)) {
-            runtimeHooks.push(hook);
-          }
-        });
-      });
-    }
-  }
-  return runtimeHooks;
-});
-function initMixinRuntimeHooks(mpOptions) {
-  initHooks(mpOptions, findMixinRuntimeHooks());
-}
-const HOOKS = [
-  ON_SHOW,
-  ON_HIDE,
-  ON_ERROR,
-  ON_THEME_CHANGE,
-  ON_PAGE_NOT_FOUND,
-  ON_UNHANDLE_REJECTION
-];
-function parseApp(instance, parseAppOptions) {
-  const internalInstance = instance.$;
-  const appOptions = {
-    globalData: instance.$options && instance.$options.globalData || {},
-    $vm: instance,
-    onLaunch(options) {
-      this.$vm = instance;
-      const ctx = internalInstance.ctx;
-      if (this.$vm && ctx.$scope) {
-        return;
-      }
-      initBaseInstance(internalInstance, {
-        mpType: "app",
-        mpInstance: this,
-        slots: []
-      });
-      ctx.globalData = this.globalData;
-      instance.$callHook(ON_LAUNCH, options);
-    }
-  };
-  initLocale(instance);
-  const vueOptions = instance.$.type;
-  initHooks(appOptions, HOOKS);
-  initUnknownHooks(appOptions, vueOptions);
-  {
-    const methods = vueOptions.methods;
-    methods && extend(appOptions, methods);
-  }
-  if (parseAppOptions) {
-    parseAppOptions.parse(appOptions);
-  }
-  return appOptions;
-}
-function initCreateApp(parseAppOptions) {
-  return function createApp2(vm) {
-    return App(parseApp(vm, parseAppOptions));
-  };
-}
-function initCreateSubpackageApp(parseAppOptions) {
-  return function createApp2(vm) {
-    const appOptions = parseApp(vm, parseAppOptions);
-    const app = getApp({
-      allowDefault: true
-    });
-    vm.$.ctx.$scope = app;
-    const globalData = app.globalData;
-    if (globalData) {
-      Object.keys(appOptions.globalData).forEach((name) => {
-        if (!hasOwn(globalData, name)) {
-          globalData[name] = appOptions.globalData[name];
-        }
-      });
-    }
-    Object.keys(appOptions).forEach((name) => {
-      if (!hasOwn(app, name)) {
-        app[name] = appOptions[name];
-      }
-    });
-    initAppLifecycle(appOptions, vm);
-  };
-}
-function initAppLifecycle(appOptions, vm) {
-  if (isFunction(appOptions.onLaunch)) {
-    const args = wx.getLaunchOptionsSync && wx.getLaunchOptionsSync();
-    appOptions.onLaunch(args);
-  }
-  if (isFunction(appOptions.onShow) && wx.onAppShow) {
-    wx.onAppShow((args) => {
-      vm.$callHook("onShow", args);
-    });
-  }
-  if (isFunction(appOptions.onHide) && wx.onAppHide) {
-    wx.onAppHide((args) => {
-      vm.$callHook("onHide", args);
-    });
-  }
-}
-function initLocale(appVm) {
-  const locale = ref(normalizeLocale(wx.getSystemInfoSync().language) || LOCALE_EN);
-  Object.defineProperty(appVm, "$locale", {
-    get() {
-      return locale.value;
-    },
-    set(v) {
-      locale.value = v;
-    }
-  });
-}
-function initVueIds(vueIds, mpInstance) {
-  if (!vueIds) {
-    return;
-  }
-  const ids = vueIds.split(",");
-  const len = ids.length;
-  if (len === 1) {
-    mpInstance._$vueId = ids[0];
-  } else if (len === 2) {
-    mpInstance._$vueId = ids[0];
-    mpInstance._$vuePid = ids[1];
-  }
-}
-const EXTRAS = ["externalClasses"];
-function initExtraOptions(miniProgramComponentOptions, vueOptions) {
-  EXTRAS.forEach((name) => {
-    if (hasOwn(vueOptions, name)) {
-      miniProgramComponentOptions[name] = vueOptions[name];
-    }
-  });
-}
-function initWxsCallMethods(methods, wxsCallMethods) {
-  if (!isArray(wxsCallMethods)) {
-    return;
-  }
-  wxsCallMethods.forEach((callMethod) => {
-    methods[callMethod] = function(args) {
-      return this.$vm[callMethod](args);
-    };
-  });
-}
-function selectAllComponents(mpInstance, selector, $refs) {
-  const components = mpInstance.selectAllComponents(selector);
-  components.forEach((component) => {
-    const ref2 = component.properties.uR;
-    $refs[ref2] = component.$vm || component;
-  });
-}
-function initRefs(instance, mpInstance) {
-  Object.defineProperty(instance, "refs", {
-    get() {
-      const $refs = {};
-      selectAllComponents(mpInstance, ".r", $refs);
-      const forComponents = mpInstance.selectAllComponents(".r-i-f");
-      forComponents.forEach((component) => {
-        const ref2 = component.properties.uR;
-        if (!ref2) {
-          return;
-        }
-        if (!$refs[ref2]) {
-          $refs[ref2] = [];
-        }
-        $refs[ref2].push(component.$vm || component);
-      });
-      return $refs;
-    }
-  });
-}
-function findVmByVueId(instance, vuePid) {
-  const $children = instance.$children;
-  for (let i = $children.length - 1; i >= 0; i--) {
-    const childVm = $children[i];
-    if (childVm.$scope._$vueId === vuePid) {
-      return childVm;
-    }
-  }
-  let parentVm;
-  for (let i = $children.length - 1; i >= 0; i--) {
-    parentVm = findVmByVueId($children[i], vuePid);
-    if (parentVm) {
-      return parentVm;
-    }
-  }
-}
-const builtInProps = [
-  "eO",
-  "uR",
-  "uRIF",
-  "uI",
-  "uT",
-  "uP",
-  "uS"
-];
-function initDefaultProps(isBehavior = false) {
-  const properties = {};
-  if (!isBehavior) {
-    builtInProps.forEach((name) => {
-      properties[name] = {
-        type: null,
-        value: ""
-      };
-    });
-    properties.uS = {
-      type: null,
-      value: [],
-      observer: function(newVal) {
-        const $slots = /* @__PURE__ */ Object.create(null);
-        newVal && newVal.forEach((slotName) => {
-          $slots[slotName] = true;
-        });
-        this.setData({
-          $slots
-        });
-      }
-    };
-  }
-  return properties;
-}
-function initVirtualHostProps(options) {
-  const properties = {};
-  {
-    if (options && options.virtualHost) {
-      properties.virtualHostStyle = {
-        type: null,
-        value: ""
-      };
-      properties.virtualHostClass = {
-        type: null,
-        value: ""
-      };
-    }
-  }
-  return properties;
-}
-function initProps(mpComponentOptions) {
-  if (!mpComponentOptions.properties) {
-    mpComponentOptions.properties = {};
-  }
-  extend(mpComponentOptions.properties, initDefaultProps(), initVirtualHostProps(mpComponentOptions.options));
-}
-const PROP_TYPES = [String, Number, Boolean, Object, Array, null];
-function parsePropType(type, defaultValue) {
-  if (isArray(type) && type.length === 1) {
-    return type[0];
-  }
-  return type;
-}
-function normalizePropType(type, defaultValue) {
-  const res = parsePropType(type);
-  return PROP_TYPES.indexOf(res) !== -1 ? res : null;
-}
-function initPageProps({ properties }, rawProps) {
-  if (isArray(rawProps)) {
-    rawProps.forEach((key) => {
-      properties[key] = {
-        type: String,
-        value: ""
-      };
-    });
-  } else if (isPlainObject(rawProps)) {
-    Object.keys(rawProps).forEach((key) => {
-      const opts = rawProps[key];
-      if (isPlainObject(opts)) {
-        let value = opts.default;
-        if (isFunction(value)) {
-          value = value();
-        }
-        const type = opts.type;
-        opts.type = normalizePropType(type);
-        properties[key] = {
-          type: opts.type,
-          value
-        };
-      } else {
-        properties[key] = {
-          type: normalizePropType(opts)
-        };
-      }
-    });
-  }
-}
-function findPropsData(properties, isPage2) {
-  return (isPage2 ? findPagePropsData(properties) : findComponentPropsData(properties.uP)) || {};
-}
-function findPagePropsData(properties) {
-  const propsData = {};
-  if (isPlainObject(properties)) {
-    Object.keys(properties).forEach((name) => {
-      if (builtInProps.indexOf(name) === -1) {
-        propsData[name] = properties[name];
-      }
-    });
-  }
-  return propsData;
-}
-function initData(_) {
-  return {};
-}
-function initPropsObserver(componentOptions) {
-  const observe = function observe2() {
-    const up = this.properties.uP;
-    if (!up) {
-      return;
-    }
-    if (this.$vm) {
-      updateComponentProps(up, this.$vm.$);
-    } else if (this.properties.uT === "m") {
-      updateMiniProgramComponentProperties(up, this);
-    }
-  };
-  {
-    if (!componentOptions.observers) {
-      componentOptions.observers = {};
-    }
-    componentOptions.observers.uP = observe;
-  }
-}
-function updateMiniProgramComponentProperties(up, mpInstance) {
-  const prevProps = mpInstance.properties;
-  const nextProps = findComponentPropsData(up) || {};
-  if (hasPropsChanged(prevProps, nextProps, false)) {
-    mpInstance.setData(nextProps);
-  }
-}
-function updateComponentProps(up, instance) {
-  const prevProps = toRaw(instance.props);
-  const nextProps = findComponentPropsData(up) || {};
-  if (hasPropsChanged(prevProps, nextProps)) {
-    updateProps(instance, nextProps, prevProps, false);
-    if (hasQueueJob(instance.update)) {
-      invalidateJob(instance.update);
-    }
-    {
-      instance.update();
-    }
-  }
-}
-function hasPropsChanged(prevProps, nextProps, checkLen = true) {
-  const nextKeys = Object.keys(nextProps);
-  if (checkLen && nextKeys.length !== Object.keys(prevProps).length) {
-    return true;
-  }
-  for (let i = 0; i < nextKeys.length; i++) {
-    const key = nextKeys[i];
-    if (nextProps[key] !== prevProps[key]) {
-      return true;
-    }
-  }
-  return false;
-}
-function initBehaviors(vueOptions) {
-  const vueBehaviors = vueOptions.behaviors;
-  let vueProps = vueOptions.props;
-  if (!vueProps) {
-    vueOptions.props = vueProps = [];
-  }
-  const behaviors = [];
-  if (isArray(vueBehaviors)) {
-    vueBehaviors.forEach((behavior) => {
-      behaviors.push(behavior.replace("uni://", "wx://"));
-      if (behavior === "uni://form-field") {
-        if (isArray(vueProps)) {
-          vueProps.push("name");
-          vueProps.push("value");
-        } else {
-          vueProps.name = {
-            type: String,
-            default: ""
-          };
-          vueProps.value = {
-            type: [String, Number, Boolean, Array, Object, Date],
-            default: ""
-          };
-        }
-      }
-    });
-  }
-  return behaviors;
-}
-function applyOptions(componentOptions, vueOptions) {
-  componentOptions.data = initData();
-  componentOptions.behaviors = initBehaviors(vueOptions);
-}
-function parseComponent(vueOptions, { parse, mocks: mocks2, isPage: isPage2, initRelation: initRelation2, handleLink: handleLink2, initLifetimes: initLifetimes2 }) {
-  vueOptions = vueOptions.default || vueOptions;
-  const options = {
-    multipleSlots: true,
-    addGlobalClass: true,
-    pureDataPattern: /^uP$/
-  };
-  if (vueOptions.options) {
-    extend(options, vueOptions.options);
-  }
-  const mpComponentOptions = {
-    options,
-    lifetimes: initLifetimes2({ mocks: mocks2, isPage: isPage2, initRelation: initRelation2, vueOptions }),
-    pageLifetimes: {
-      show() {
-        this.$vm && this.$vm.$callHook("onPageShow");
-      },
-      hide() {
-        this.$vm && this.$vm.$callHook("onPageHide");
-      },
-      resize(size2) {
-        this.$vm && this.$vm.$callHook("onPageResize", size2);
-      }
-    },
-    methods: {
-      __l: handleLink2
-    }
-  };
-  {
-    applyOptions(mpComponentOptions, vueOptions);
-  }
-  initProps(mpComponentOptions);
-  initPropsObserver(mpComponentOptions);
-  initExtraOptions(mpComponentOptions, vueOptions);
-  initWxsCallMethods(mpComponentOptions.methods, vueOptions.wxsCallMethods);
-  if (parse) {
-    parse(mpComponentOptions, { handleLink: handleLink2 });
-  }
-  return mpComponentOptions;
-}
-function initCreateComponent(parseOptions2) {
-  return function createComponent2(vueComponentOptions) {
-    return Component(parseComponent(vueComponentOptions, parseOptions2));
-  };
-}
-let $createComponentFn;
-let $destroyComponentFn;
-function getAppVm() {
-  return getApp().$vm;
-}
-function $createComponent(initialVNode, options) {
-  if (!$createComponentFn) {
-    $createComponentFn = getAppVm().$createComponent;
-  }
-  const proxy = $createComponentFn(initialVNode, options);
-  return getExposeProxy(proxy.$) || proxy;
-}
-function $destroyComponent(instance) {
-  if (!$destroyComponentFn) {
-    $destroyComponentFn = getApp().$vm.$destroyComponent;
-  }
-  return $destroyComponentFn(instance);
-}
-function parsePage(vueOptions, parseOptions2) {
-  const { parse, mocks: mocks2, isPage: isPage2, initRelation: initRelation2, handleLink: handleLink2, initLifetimes: initLifetimes2 } = parseOptions2;
-  const miniProgramPageOptions = parseComponent(vueOptions, {
-    mocks: mocks2,
-    isPage: isPage2,
-    initRelation: initRelation2,
-    handleLink: handleLink2,
-    initLifetimes: initLifetimes2
-  });
-  initPageProps(miniProgramPageOptions, (vueOptions.default || vueOptions).props);
-  const methods = miniProgramPageOptions.methods;
-  methods.onLoad = function(query) {
-    this.options = query;
-    this.$page = {
-      fullPath: addLeadingSlash(this.route + stringifyQuery(query))
-    };
-    return this.$vm && this.$vm.$callHook(ON_LOAD, query);
-  };
-  initHooks(methods, PAGE_INIT_HOOKS);
-  {
-    initUnknownHooks(methods, vueOptions);
-  }
-  initRuntimeHooks(methods, vueOptions.__runtimeHooks);
-  initMixinRuntimeHooks(methods);
-  parse && parse(miniProgramPageOptions, { handleLink: handleLink2 });
-  return miniProgramPageOptions;
-}
-function initCreatePage(parseOptions2) {
-  return function createPage2(vuePageOptions) {
-    return Component(parsePage(vuePageOptions, parseOptions2));
-  };
-}
-function initCreatePluginApp(parseAppOptions) {
-  return function createApp2(vm) {
-    initAppLifecycle(parseApp(vm, parseAppOptions), vm);
-  };
-}
-const MPPage = Page;
-const MPComponent = Component;
-function initTriggerEvent(mpInstance) {
-  const oldTriggerEvent = mpInstance.triggerEvent;
-  mpInstance.triggerEvent = function(event, ...args) {
-    return oldTriggerEvent.apply(mpInstance, [customizeEvent(event), ...args]);
-  };
-}
-function initMiniProgramHook(name, options, isComponent) {
-  const oldHook = options[name];
-  if (!oldHook) {
-    options[name] = function() {
-      initTriggerEvent(this);
-    };
-  } else {
-    options[name] = function(...args) {
-      initTriggerEvent(this);
-      return oldHook.apply(this, args);
-    };
-  }
-}
-Page = function(options) {
-  initMiniProgramHook(ON_LOAD, options);
-  return MPPage(options);
-};
-Component = function(options) {
-  initMiniProgramHook("created", options);
-  const isVueComponent = options.properties && options.properties.uP;
-  if (!isVueComponent) {
-    initProps(options);
-    initPropsObserver(options);
-  }
-  return MPComponent(options);
-};
-function initLifetimes({ mocks: mocks2, isPage: isPage2, initRelation: initRelation2, vueOptions }) {
-  return {
-    attached() {
-      let properties = this.properties;
-      initVueIds(properties.uI, this);
-      const relationOptions = {
-        vuePid: this._$vuePid
-      };
-      initRelation2(this, relationOptions);
-      const mpInstance = this;
-      const isMiniProgramPage = isPage2(mpInstance);
-      let propsData = properties;
-      this.$vm = $createComponent({
-        type: vueOptions,
-        props: findPropsData(propsData, isMiniProgramPage)
-      }, {
-        mpType: isMiniProgramPage ? "page" : "component",
-        mpInstance,
-        slots: properties.uS || {},
-        parentComponent: relationOptions.parent && relationOptions.parent.$,
-        onBeforeSetup(instance, options) {
-          initRefs(instance, mpInstance);
-          initMocks(instance, mpInstance, mocks2);
-          initComponentInstance(instance, options);
-        }
-      });
-    },
-    ready() {
-      if (this.$vm) {
-        {
-          this.$vm.$callHook("mounted");
-          this.$vm.$callHook(ON_READY);
-        }
-      }
-    },
-    detached() {
-      if (this.$vm) {
-        pruneComponentPropsCache(this.$vm.$.uid);
-        $destroyComponent(this.$vm);
-      }
-    }
-  };
-}
-const mocks = ["__route__", "__wxExparserNodeId__", "__wxWebviewId__"];
-function isPage(mpInstance) {
-  return !!mpInstance.route;
-}
-function initRelation(mpInstance, detail) {
-  mpInstance.triggerEvent("__l", detail);
-}
-function handleLink(event) {
-  const detail = event.detail || event.value;
-  const vuePid = detail.vuePid;
-  let parentVm;
-  if (vuePid) {
-    parentVm = findVmByVueId(this.$vm, vuePid);
-  }
-  if (!parentVm) {
-    parentVm = this.$vm;
-  }
-  detail.parent = parentVm;
-}
-var parseOptions = /* @__PURE__ */ Object.freeze({
-  __proto__: null,
-  mocks,
-  isPage,
-  initRelation,
-  handleLink,
-  initLifetimes
-});
-const createApp = initCreateApp();
-const createPage = initCreatePage(parseOptions);
-const createComponent = initCreateComponent(parseOptions);
-const createPluginApp = initCreatePluginApp();
-const createSubpackageApp = initCreateSubpackageApp();
-{
-  wx.createApp = global.createApp = createApp;
-  wx.createPage = createPage;
-  wx.createComponent = createComponent;
-  wx.createPluginApp = global.createPluginApp = createPluginApp;
-  wx.createSubpackageApp = global.createSubpackageApp = createSubpackageApp;
-}
-var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
-var timUploadPlugin = { exports: {} };
-(function(module, exports2) {
-  var factory;
-  factory = function() {
-    function e2(e3, t3) {
-      var n3 = Object.keys(e3);
-      if (Object.getOwnPropertySymbols) {
-        var o3 = Object.getOwnPropertySymbols(e3);
-        t3 && (o3 = o3.filter(function(t4) {
-          return Object.getOwnPropertyDescriptor(e3, t4).enumerable;
-        })), n3.push.apply(n3, o3);
-      }
-      return n3;
-    }
-    function t2(t3) {
-      for (var n3 = 1; n3 < arguments.length; n3++) {
-        var o3 = arguments[n3] != null ? arguments[n3] : {};
-        n3 % 2 ? e2(Object(o3), true).forEach(function(e3) {
-          s2(t3, e3, o3[e3]);
-        }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(t3, Object.getOwnPropertyDescriptors(o3)) : e2(Object(o3)).forEach(function(e3) {
-          Object.defineProperty(t3, e3, Object.getOwnPropertyDescriptor(o3, e3));
-        });
-      }
-      return t3;
-    }
-    function n2(e3) {
-      return (n2 = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(e4) {
-        return typeof e4;
-      } : function(e4) {
-        return e4 && typeof Symbol == "function" && e4.constructor === Symbol && e4 !== Symbol.prototype ? "symbol" : typeof e4;
-      })(e3);
-    }
-    function o2(e3, t3) {
-      if (!(e3 instanceof t3))
-        throw new TypeError("Cannot call a class as a function");
-    }
-    function r(e3, t3) {
-      for (var n3 = 0; n3 < t3.length; n3++) {
-        var o3 = t3[n3];
-        o3.enumerable = o3.enumerable || false, o3.configurable = true, "value" in o3 && (o3.writable = true), Object.defineProperty(e3, o3.key, o3);
-      }
-    }
-    function a(e3, t3, n3) {
-      return t3 && r(e3.prototype, t3), n3 && r(e3, n3), Object.defineProperty(e3, "prototype", { writable: false }), e3;
-    }
-    function s2(e3, t3, n3) {
-      return t3 in e3 ? Object.defineProperty(e3, t3, { value: n3, enumerable: true, configurable: true, writable: true }) : e3[t3] = n3, e3;
-    }
-    function i(e3, t3) {
-      if (e3 == null)
-        return {};
-      var n3, o3, r2 = function(e4, t4) {
-        if (e4 == null)
-          return {};
-        var n4, o4, r3 = {}, a3 = Object.keys(e4);
-        for (o4 = 0; o4 < a3.length; o4++)
-          n4 = a3[o4], t4.indexOf(n4) >= 0 || (r3[n4] = e4[n4]);
-        return r3;
-      }(e3, t3);
-      if (Object.getOwnPropertySymbols) {
-        var a2 = Object.getOwnPropertySymbols(e3);
-        for (o3 = 0; o3 < a2.length; o3++)
-          n3 = a2[o3], t3.indexOf(n3) >= 0 || Object.prototype.propertyIsEnumerable.call(e3, n3) && (r2[n3] = e3[n3]);
-      }
-      return r2;
-    }
-    var f2 = typeof wx != "undefined" && typeof wx.getSystemInfoSync == "function" && Boolean(wx.getSystemInfoSync().fontSizeSetting), u = typeof qq != "undefined" && typeof qq.getSystemInfoSync == "function" && Boolean(qq.getSystemInfoSync().fontSizeSetting), l = typeof tt != "undefined" && typeof tt.getSystemInfoSync == "function" && Boolean(tt.getSystemInfoSync().fontSizeSetting), c = typeof swan != "undefined" && typeof swan.getSystemInfoSync == "function" && Boolean(swan.getSystemInfoSync().fontSizeSetting), y = typeof my != "undefined" && typeof my.getSystemInfoSync == "function" && Boolean(my.getSystemInfoSync().fontSizeSetting), d = typeof index != "undefined" && typeof window == "undefined" && typeof index.requireNativePlugin == "function", p2 = d && index.getDeviceInfo().platform.toLocaleLowerCase() === "ios", g = (d && index.getDeviceInfo().platform.toLocaleLowerCase(), f2 || u || l || c || y || d), m = u ? qq : l ? tt : c ? swan : y ? my : f2 ? wx : d ? index : {}, h = function(e3) {
-      if (n2(e3) !== "object" || e3 === null)
-        return false;
-      var t3 = Object.getPrototypeOf(e3);
-      if (t3 === null)
-        return true;
-      for (var o3 = t3; Object.getPrototypeOf(o3) !== null; )
-        o3 = Object.getPrototypeOf(o3);
-      return t3 === o3;
-    };
-    function v(e3) {
-      if (e3 == null)
-        return true;
-      if (typeof e3 == "boolean")
-        return false;
-      if (typeof e3 == "number")
-        return e3 === 0;
-      if (typeof e3 == "string")
-        return e3.length === 0;
-      if (typeof e3 == "function")
-        return e3.length === 0;
-      if (Array.isArray(e3))
-        return e3.length === 0;
-      if (e3 instanceof Error)
-        return e3.message === "";
-      if (h(e3)) {
-        for (var t3 in e3)
-          if (Object.prototype.hasOwnProperty.call(e3, t3))
-            return false;
-        return true;
-      }
-      return false;
-    }
-    var b = function() {
-      function e3() {
-        o2(this, e3);
-      }
-      return a(e3, [{ key: "request", value: function(e4, t3) {
-        var n3 = this, o3 = e4.downloadUrl || "", r2 = (e4.method || "PUT").toUpperCase(), a2 = e4.url;
-        if (e4.qs) {
-          var s3 = function(e5) {
-            var t4 = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : "&", n4 = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : "=";
-            return v(e5) ? "" : h(e5) ? Object.keys(e5).map(function(o4) {
-              var r3 = encodeURIComponent(o4) + n4;
-              return Array.isArray(e5[o4]) ? e5[o4].map(function(e6) {
-                return r3 + encodeURIComponent(e6);
-              }).join(t4) : r3 + encodeURIComponent(e5[o4]);
-            }).filter(Boolean).join(t4) : void 0;
-          }(e4.qs);
-          s3 && (a2 += "".concat(a2.indexOf("?") === -1 ? "?" : "&").concat(s3));
-        }
-        var i2 = new XMLHttpRequest();
-        i2.open(r2, a2, true), i2.responseType = e4.dataType || "text";
-        var f3 = e4.headers || {};
-        if (!v(f3))
-          for (var u2 in f3)
-            f3.hasOwnProperty(u2) && u2.toLowerCase() !== "content-length" && u2.toLowerCase() !== "user-agent" && u2.toLowerCase() !== "origin" && u2.toLowerCase() !== "host" && i2.setRequestHeader(u2, f3[u2]);
-        return i2.onload = function() {
-          if (i2.status === 200)
-            t3(null, n3._xhrRes(i2, n3._xhrBody(i2, o3)));
-          else {
-            var e5 = { code: i2.status, message: JSON.stringify(i2.responseText) };
-            t3(e5, n3._xhrRes(i2, n3._xhrBody(i2)));
-          }
-        }, i2.onerror = function(e5) {
-          var o4 = n3._xhrBody(i2), r3 = { code: i2.status, message: JSON.stringify(i2.responseText) };
-          o4 || i2.statusText || i2.status !== 0 || (e5.message = "CORS blocked or network error"), t3(r3, n3._xhrRes(i2, o4)), r3 = null;
-        }, e4.onProgress && i2.upload && (i2.upload.onprogress = function(t4) {
-          var n4 = t4.total, o4 = t4.loaded, r3 = Math.floor(100 * o4 / n4);
-          e4.onProgress({ total: n4, loaded: o4, percent: (r3 >= 100 ? 100 : r3) / 100 });
-        }), i2.send(e4.resources), i2;
-      } }, { key: "_xhrRes", value: function(e4, t3) {
-        var n3 = {};
-        return e4.getAllResponseHeaders().trim().split("\n").forEach(function(e5) {
-          if (e5) {
-            var t4 = e5.indexOf(":"), o3 = e5.substr(0, t4).trim().toLowerCase(), r2 = e5.substr(t4 + 1).trim();
-            n3[o3] = r2;
-          }
-        }), { statusCode: e4.status, statusMessage: e4.statusText, headers: n3, data: t3 };
-      } }, { key: "_xhrBody", value: function(e4, t3) {
-        return e4.status === 200 && t3 ? { location: t3 } : { response: e4.responseText };
-      } }]), e3;
-    }(), O = ["unknown", "image", "video", "audio", "log"], w = ["name"], S = function() {
-      function e3() {
-        o2(this, e3);
-      }
-      return a(e3, [{ key: "request", value: function(e4, n3) {
-        var o3 = this, r2 = e4.resources, a2 = r2 === void 0 ? "" : r2, s3 = e4.headers, f3 = s3 === void 0 ? {} : s3, u2 = e4.url, l2 = e4.downloadUrl, c2 = l2 === void 0 ? "" : l2, d2 = u2, g2 = null, h2 = c2.match(/^(https?:\/\/[^/]+\/)([^/]*\/?)(.*)$/), v2 = decodeURIComponent(h2[3]), b2 = { key: v2.indexOf("?") > -1 ? v2.split("?")[0] : v2, success_action_status: 200, "Content-Type": "" }, S2 = {};
-        if (p2) {
-          var C = u2.split("?sign=");
-          if (C.length > 1) {
-            var P = C[1];
-            d2 = "".concat(C[0], "?sign=").concat(encodeURIComponent("".concat(P))), S2.sign = decodeURIComponent(P), S2.signature = decodeURIComponent(P);
-          }
-        }
-        var j = { url: d2, header: f3, name: "file", filePath: a2, formData: t2(t2({}, b2), S2), timeout: e4.timeout || 3e5 };
-        if (y) {
-          var x = j;
-          x.name, j = t2(t2({}, i(x, w)), {}, { fileName: "file", fileType: O[e4.fileType] });
-        }
-        return (g2 = m.uploadFile(t2(t2({}, j), {}, { success: function(e5) {
-          o3._handleResponse({ response: e5, downloadUrl: c2, callback: n3 });
-        }, fail: function(e5) {
-          o3._handleResponse({ response: e5, downloadUrl: c2, callback: n3 });
-        } }))).onProgressUpdate && g2.onProgressUpdate(function(t3) {
-          e4.onProgress && e4.onProgress({ total: t3.totalBytesExpectedToSend, loaded: t3.totalBytesSent, percent: Math.floor(t3.progress) / 100 });
-        }), g2;
-      } }, { key: "_handleResponse", value: function(e4) {
-        var n3 = e4.downloadUrl, o3 = e4.response, r2 = e4.callback, a2 = o3.header, s3 = {};
-        if (a2)
-          for (var i2 in a2)
-            a2.hasOwnProperty(i2) && (s3[i2.toLowerCase()] = a2[i2]);
-        var f3 = +o3.statusCode;
-        f3 === 200 ? r2(null, { statusCode: f3, headers: s3, data: t2(t2({}, o3.data), {}, { location: n3 }) }) : r2({ code: f3, message: JSON.stringify(o3.data) }, { statusCode: f3, headers: s3, data: void 0 });
-      } }]), e3;
-    }();
-    return function() {
-      function e3() {
-        o2(this, e3), console.log("TIMUploadPlugin.VERSION: ".concat("1.2.0")), this.retry = 1, this.tryCount = 0, this.systemClockOffset = 0, this.httpRequest = g ? new S() : new b();
-      }
-      return a(e3, [{ key: "uploadFile", value: function(e4, t3) {
-        var n3 = this;
-        return this.httpRequest.request(e4, function(o3, r2) {
-          o3 && n3.tryCount < n3.retry && n3.allowRetry(o3) ? (n3.tryCount++, n3.uploadFile(e4, t3)) : (n3.tryCount = 0, t3(o3, r2));
-        });
-      } }, { key: "allowRetry", value: function(e4) {
-        var t3 = false, n3 = false;
-        if (e4) {
-          var o3 = e4.headers && (e4.headers.date || e4.headers.Date) || e4.error && e4.error.ServerTime;
-          try {
-            var r2 = e4.error && e4.error.Code, a2 = e4.error && e4.error.Message;
-            (r2 === "RequestTimeTooSkewed" || r2 === "AccessDenied" && a2 === "Request has expired") && (n3 = true);
-          } catch (f3) {
-          }
-          if (n3 && o3) {
-            var s3 = Date.now(), i2 = Date.parse(o3);
-            Math.abs(s3 + this.systemClockOffset - i2) >= 3e4 && (this.systemClockOffset = i2 - s3, t3 = true);
-          } else
-            Math.floor(e4.statusCode / 100) === 5 && (t3 = true);
-        }
-        return t3;
-      } }]), e3;
-    }();
-  }, module.exports = factory();
-})(timUploadPlugin);
-var TIMUploadPlugin = timUploadPlugin.exports;
-/*!
- * vuex v4.0.2
- * (c) 2021 Evan You
- * @license MIT
- */
-var storeKey = "store";
-function forEachValue(obj, fn) {
-  Object.keys(obj).forEach(function(key) {
-    return fn(obj[key], key);
-  });
-}
-function isObject(obj) {
-  return obj !== null && typeof obj === "object";
-}
-function isPromise(val) {
-  return val && typeof val.then === "function";
-}
-function assert(condition, msg) {
-  if (!condition) {
-    throw new Error("[vuex] " + msg);
-  }
-}
-function partial(fn, arg) {
-  return function() {
-    return fn(arg);
-  };
-}
-function genericSubscribe(fn, subs, options) {
-  if (subs.indexOf(fn) < 0) {
-    options && options.prepend ? subs.unshift(fn) : subs.push(fn);
-  }
-  return function() {
-    var i = subs.indexOf(fn);
-    if (i > -1) {
-      subs.splice(i, 1);
-    }
-  };
-}
-function resetStore(store, hot) {
-  store._actions = /* @__PURE__ */ Object.create(null);
-  store._mutations = /* @__PURE__ */ Object.create(null);
-  store._wrappedGetters = /* @__PURE__ */ Object.create(null);
-  store._modulesNamespaceMap = /* @__PURE__ */ Object.create(null);
-  var state = store.state;
-  installModule(store, state, [], store._modules.root, true);
-  resetStoreState(store, state, hot);
-}
-function resetStoreState(store, state, hot) {
-  var oldState = store._state;
-  store.getters = {};
-  store._makeLocalGettersCache = /* @__PURE__ */ Object.create(null);
-  var wrappedGetters = store._wrappedGetters;
-  var computedObj = {};
-  forEachValue(wrappedGetters, function(fn, key) {
-    computedObj[key] = partial(fn, store);
-    Object.defineProperty(store.getters, key, {
-      get: function() {
-        return computedObj[key]();
-      },
-      enumerable: true
-    });
-  });
-  store._state = reactive({
-    data: state
-  });
-  if (store.strict) {
-    enableStrictMode(store);
-  }
-  if (oldState) {
-    if (hot) {
-      store._withCommit(function() {
-        oldState.data = null;
-      });
-    }
-  }
-}
-function installModule(store, rootState, path, module, hot) {
-  var isRoot = !path.length;
-  var namespace = store._modules.getNamespace(path);
-  if (module.namespaced) {
-    if (store._modulesNamespaceMap[namespace] && true) {
-      console.error("[vuex] duplicate namespace " + namespace + " for the namespaced module " + path.join("/"));
-    }
-    store._modulesNamespaceMap[namespace] = module;
-  }
-  if (!isRoot && !hot) {
-    var parentState = getNestedState(rootState, path.slice(0, -1));
-    var moduleName = path[path.length - 1];
-    store._withCommit(function() {
-      {
-        if (moduleName in parentState) {
-          console.warn('[vuex] state field "' + moduleName + '" was overridden by a module with the same name at "' + path.join(".") + '"');
-        }
-      }
-      parentState[moduleName] = module.state;
-    });
-  }
-  var local = module.context = makeLocalContext(store, namespace, path);
-  module.forEachMutation(function(mutation, key) {
-    var namespacedType = namespace + key;
-    registerMutation(store, namespacedType, mutation, local);
-  });
-  module.forEachAction(function(action, key) {
-    var type = action.root ? key : namespace + key;
-    var handler = action.handler || action;
-    registerAction(store, type, handler, local);
-  });
-  module.forEachGetter(function(getter, key) {
-    var namespacedType = namespace + key;
-    registerGetter(store, namespacedType, getter, local);
-  });
-  module.forEachChild(function(child, key) {
-    installModule(store, rootState, path.concat(key), child, hot);
-  });
-}
-function makeLocalContext(store, namespace, path) {
-  var noNamespace = namespace === "";
-  var local = {
-    dispatch: noNamespace ? store.dispatch : function(_type, _payload, _options) {
-      var args = unifyObjectStyle(_type, _payload, _options);
-      var payload = args.payload;
-      var options = args.options;
-      var type = args.type;
-      if (!options || !options.root) {
-        type = namespace + type;
-        if (!store._actions[type]) {
-          console.error("[vuex] unknown local action type: " + args.type + ", global type: " + type);
-          return;
-        }
-      }
-      return store.dispatch(type, payload);
-    },
-    commit: noNamespace ? store.commit : function(_type, _payload, _options) {
-      var args = unifyObjectStyle(_type, _payload, _options);
-      var payload = args.payload;
-      var options = args.options;
-      var type = args.type;
-      if (!options || !options.root) {
-        type = namespace + type;
-        if (!store._mutations[type]) {
-          console.error("[vuex] unknown local mutation type: " + args.type + ", global type: " + type);
-          return;
-        }
-      }
-      store.commit(type, payload, options);
-    }
-  };
-  Object.defineProperties(local, {
-    getters: {
-      get: noNamespace ? function() {
-        return store.getters;
-      } : function() {
-        return makeLocalGetters(store, namespace);
-      }
-    },
-    state: {
-      get: function() {
-        return getNestedState(store.state, path);
-      }
-    }
-  });
-  return local;
-}
-function makeLocalGetters(store, namespace) {
-  if (!store._makeLocalGettersCache[namespace]) {
-    var gettersProxy = {};
-    var splitPos = namespace.length;
-    Object.keys(store.getters).forEach(function(type) {
-      if (type.slice(0, splitPos) !== namespace) {
-        return;
-      }
-      var localType = type.slice(splitPos);
-      Object.defineProperty(gettersProxy, localType, {
-        get: function() {
-          return store.getters[type];
-        },
-        enumerable: true
-      });
-    });
-    store._makeLocalGettersCache[namespace] = gettersProxy;
-  }
-  return store._makeLocalGettersCache[namespace];
-}
-function registerMutation(store, type, handler, local) {
-  var entry = store._mutations[type] || (store._mutations[type] = []);
-  entry.push(function wrappedMutationHandler(payload) {
-    handler.call(store, local.state, payload);
-  });
-}
-function registerAction(store, type, handler, local) {
-  var entry = store._actions[type] || (store._actions[type] = []);
-  entry.push(function wrappedActionHandler(payload) {
-    var res = handler.call(store, {
-      dispatch: local.dispatch,
-      commit: local.commit,
-      getters: local.getters,
-      state: local.state,
-      rootGetters: store.getters,
-      rootState: store.state
-    }, payload);
-    if (!isPromise(res)) {
-      res = Promise.resolve(res);
-    }
-    if (store._devtoolHook) {
-      return res.catch(function(err) {
-        store._devtoolHook.emit("vuex:error", err);
-        throw err;
-      });
-    } else {
-      return res;
-    }
-  });
-}
-function registerGetter(store, type, rawGetter, local) {
-  if (store._wrappedGetters[type]) {
-    {
-      console.error("[vuex] duplicate getter key: " + type);
-    }
-    return;
-  }
-  store._wrappedGetters[type] = function wrappedGetter(store2) {
-    return rawGetter(local.state, local.getters, store2.state, store2.getters);
-  };
-}
-function enableStrictMode(store) {
-  watch(function() {
-    return store._state.data;
-  }, function() {
-    {
-      assert(store._committing, "do not mutate vuex store state outside mutation handlers.");
-    }
-  }, { deep: true, flush: "sync" });
-}
-function getNestedState(state, path) {
-  return path.reduce(function(state2, key) {
-    return state2[key];
-  }, state);
-}
-function unifyObjectStyle(type, payload, options) {
-  if (isObject(type) && type.type) {
-    options = payload;
-    payload = type;
-    type = type.type;
-  }
-  {
-    assert(typeof type === "string", "expects string as the type, but found " + typeof type + ".");
-  }
-  return { type, payload, options };
-}
-var Module = function Module2(rawModule, runtime) {
-  this.runtime = runtime;
-  this._children = /* @__PURE__ */ Object.create(null);
-  this._rawModule = rawModule;
-  var rawState = rawModule.state;
-  this.state = (typeof rawState === "function" ? rawState() : rawState) || {};
-};
-var prototypeAccessors$1 = { namespaced: { configurable: true } };
-prototypeAccessors$1.namespaced.get = function() {
-  return !!this._rawModule.namespaced;
-};
-Module.prototype.addChild = function addChild(key, module) {
-  this._children[key] = module;
-};
-Module.prototype.removeChild = function removeChild(key) {
-  delete this._children[key];
-};
-Module.prototype.getChild = function getChild(key) {
-  return this._children[key];
-};
-Module.prototype.hasChild = function hasChild(key) {
-  return key in this._children;
-};
-Module.prototype.update = function update2(rawModule) {
-  this._rawModule.namespaced = rawModule.namespaced;
-  if (rawModule.actions) {
-    this._rawModule.actions = rawModule.actions;
-  }
-  if (rawModule.mutations) {
-    this._rawModule.mutations = rawModule.mutations;
-  }
-  if (rawModule.getters) {
-    this._rawModule.getters = rawModule.getters;
-  }
-};
-Module.prototype.forEachChild = function forEachChild(fn) {
-  forEachValue(this._children, fn);
-};
-Module.prototype.forEachGetter = function forEachGetter(fn) {
-  if (this._rawModule.getters) {
-    forEachValue(this._rawModule.getters, fn);
-  }
-};
-Module.prototype.forEachAction = function forEachAction(fn) {
-  if (this._rawModule.actions) {
-    forEachValue(this._rawModule.actions, fn);
-  }
-};
-Module.prototype.forEachMutation = function forEachMutation(fn) {
-  if (this._rawModule.mutations) {
-    forEachValue(this._rawModule.mutations, fn);
-  }
-};
-Object.defineProperties(Module.prototype, prototypeAccessors$1);
-var ModuleCollection = function ModuleCollection2(rawRootModule) {
-  this.register([], rawRootModule, false);
-};
-ModuleCollection.prototype.get = function get2(path) {
-  return path.reduce(function(module, key) {
-    return module.getChild(key);
-  }, this.root);
-};
-ModuleCollection.prototype.getNamespace = function getNamespace(path) {
-  var module = this.root;
-  return path.reduce(function(namespace, key) {
-    module = module.getChild(key);
-    return namespace + (module.namespaced ? key + "/" : "");
-  }, "");
-};
-ModuleCollection.prototype.update = function update$1(rawRootModule) {
-  update([], this.root, rawRootModule);
-};
-ModuleCollection.prototype.register = function register(path, rawModule, runtime) {
-  var this$1$1 = this;
-  if (runtime === void 0)
-    runtime = true;
-  {
-    assertRawModule(path, rawModule);
-  }
-  var newModule = new Module(rawModule, runtime);
-  if (path.length === 0) {
-    this.root = newModule;
-  } else {
-    var parent = this.get(path.slice(0, -1));
-    parent.addChild(path[path.length - 1], newModule);
-  }
-  if (rawModule.modules) {
-    forEachValue(rawModule.modules, function(rawChildModule, key) {
-      this$1$1.register(path.concat(key), rawChildModule, runtime);
-    });
-  }
-};
-ModuleCollection.prototype.unregister = function unregister(path) {
-  var parent = this.get(path.slice(0, -1));
-  var key = path[path.length - 1];
-  var child = parent.getChild(key);
-  if (!child) {
-    {
-      console.warn("[vuex] trying to unregister module '" + key + "', which is not registered");
-    }
-    return;
-  }
-  if (!child.runtime) {
-    return;
-  }
-  parent.removeChild(key);
-};
-ModuleCollection.prototype.isRegistered = function isRegistered(path) {
-  var parent = this.get(path.slice(0, -1));
-  var key = path[path.length - 1];
-  if (parent) {
-    return parent.hasChild(key);
-  }
-  return false;
-};
-function update(path, targetModule, newModule) {
-  {
-    assertRawModule(path, newModule);
-  }
-  targetModule.update(newModule);
-  if (newModule.modules) {
-    for (var key in newModule.modules) {
-      if (!targetModule.getChild(key)) {
-        {
-          console.warn("[vuex] trying to add a new module '" + key + "' on hot reloading, manual reload is needed");
-        }
-        return;
-      }
-      update(path.concat(key), targetModule.getChild(key), newModule.modules[key]);
-    }
-  }
-}
-var functionAssert = {
-  assert: function(value) {
-    return typeof value === "function";
-  },
-  expected: "function"
-};
-var objectAssert = {
-  assert: function(value) {
-    return typeof value === "function" || typeof value === "object" && typeof value.handler === "function";
-  },
-  expected: 'function or object with "handler" function'
-};
-var assertTypes = {
-  getters: functionAssert,
-  mutations: functionAssert,
-  actions: objectAssert
-};
-function assertRawModule(path, rawModule) {
-  Object.keys(assertTypes).forEach(function(key) {
-    if (!rawModule[key]) {
-      return;
-    }
-    var assertOptions = assertTypes[key];
-    forEachValue(rawModule[key], function(value, type) {
-      assert(assertOptions.assert(value), makeAssertionMessage(path, key, type, value, assertOptions.expected));
-    });
-  });
-}
-function makeAssertionMessage(path, key, type, value, expected) {
-  var buf = key + " should be " + expected + ' but "' + key + "." + type + '"';
-  if (path.length > 0) {
-    buf += ' in module "' + path.join(".") + '"';
-  }
-  buf += " is " + JSON.stringify(value) + ".";
-  return buf;
-}
-function createStore(options) {
-  return new Store(options);
-}
-var Store = function Store2(options) {
-  var this$1$1 = this;
-  if (options === void 0)
-    options = {};
-  {
-    assert(typeof Promise !== "undefined", "vuex requires a Promise polyfill in this browser.");
-    assert(this instanceof Store2, "store must be called with the new operator.");
-  }
-  var plugins = options.plugins;
-  if (plugins === void 0)
-    plugins = [];
-  var strict = options.strict;
-  if (strict === void 0)
-    strict = false;
-  var devtools = options.devtools;
-  this._committing = false;
-  this._actions = /* @__PURE__ */ Object.create(null);
-  this._actionSubscribers = [];
-  this._mutations = /* @__PURE__ */ Object.create(null);
-  this._wrappedGetters = /* @__PURE__ */ Object.create(null);
-  this._modules = new ModuleCollection(options);
-  this._modulesNamespaceMap = /* @__PURE__ */ Object.create(null);
-  this._subscribers = [];
-  this._makeLocalGettersCache = /* @__PURE__ */ Object.create(null);
-  this._devtools = devtools;
-  var store = this;
-  var ref2 = this;
-  var dispatch2 = ref2.dispatch;
-  var commit2 = ref2.commit;
-  this.dispatch = function boundDispatch(type, payload) {
-    return dispatch2.call(store, type, payload);
-  };
-  this.commit = function boundCommit(type, payload, options2) {
-    return commit2.call(store, type, payload, options2);
-  };
-  this.strict = strict;
-  var state = this._modules.root.state;
-  installModule(this, state, [], this._modules.root);
-  resetStoreState(this, state);
-  plugins.forEach(function(plugin2) {
-    return plugin2(this$1$1);
-  });
-};
-var prototypeAccessors = { state: { configurable: true } };
-Store.prototype.install = function install(app, injectKey) {
-  app.provide(injectKey || storeKey, this);
-  app.config.globalProperties.$store = this;
-  this._devtools !== void 0 ? this._devtools : true;
-};
-prototypeAccessors.state.get = function() {
-  return this._state.data;
-};
-prototypeAccessors.state.set = function(v) {
-  {
-    assert(false, "use store.replaceState() to explicit replace store state.");
-  }
-};
-Store.prototype.commit = function commit(_type, _payload, _options) {
-  var this$1$1 = this;
-  var ref2 = unifyObjectStyle(_type, _payload, _options);
-  var type = ref2.type;
-  var payload = ref2.payload;
-  var options = ref2.options;
-  var mutation = { type, payload };
-  var entry = this._mutations[type];
-  if (!entry) {
-    {
-      console.error("[vuex] unknown mutation type: " + type);
-    }
-    return;
-  }
-  this._withCommit(function() {
-    entry.forEach(function commitIterator(handler) {
-      handler(payload);
-    });
-  });
-  this._subscribers.slice().forEach(function(sub) {
-    return sub(mutation, this$1$1.state);
-  });
-  if (options && options.silent) {
-    console.warn("[vuex] mutation type: " + type + ". Silent option has been removed. Use the filter functionality in the vue-devtools");
-  }
-};
-Store.prototype.dispatch = function dispatch(_type, _payload) {
-  var this$1$1 = this;
-  var ref2 = unifyObjectStyle(_type, _payload);
-  var type = ref2.type;
-  var payload = ref2.payload;
-  var action = { type, payload };
-  var entry = this._actions[type];
-  if (!entry) {
-    {
-      console.error("[vuex] unknown action type: " + type);
-    }
-    return;
-  }
-  try {
-    this._actionSubscribers.slice().filter(function(sub) {
-      return sub.before;
-    }).forEach(function(sub) {
-      return sub.before(action, this$1$1.state);
-    });
-  } catch (e2) {
-    {
-      console.warn("[vuex] error in before action subscribers: ");
-      console.error(e2);
-    }
-  }
-  var result = entry.length > 1 ? Promise.all(entry.map(function(handler) {
-    return handler(payload);
-  })) : entry[0](payload);
-  return new Promise(function(resolve2, reject) {
-    result.then(function(res) {
-      try {
-        this$1$1._actionSubscribers.filter(function(sub) {
-          return sub.after;
-        }).forEach(function(sub) {
-          return sub.after(action, this$1$1.state);
-        });
-      } catch (e2) {
-        {
-          console.warn("[vuex] error in after action subscribers: ");
-          console.error(e2);
-        }
-      }
-      resolve2(res);
-    }, function(error) {
-      try {
-        this$1$1._actionSubscribers.filter(function(sub) {
-          return sub.error;
-        }).forEach(function(sub) {
-          return sub.error(action, this$1$1.state, error);
-        });
-      } catch (e2) {
-        {
-          console.warn("[vuex] error in error action subscribers: ");
-          console.error(e2);
-        }
-      }
-      reject(error);
-    });
-  });
-};
-Store.prototype.subscribe = function subscribe(fn, options) {
-  return genericSubscribe(fn, this._subscribers, options);
-};
-Store.prototype.subscribeAction = function subscribeAction(fn, options) {
-  var subs = typeof fn === "function" ? { before: fn } : fn;
-  return genericSubscribe(subs, this._actionSubscribers, options);
-};
-Store.prototype.watch = function watch$1(getter, cb, options) {
-  var this$1$1 = this;
-  {
-    assert(typeof getter === "function", "store.watch only accepts a function.");
-  }
-  return watch(function() {
-    return getter(this$1$1.state, this$1$1.getters);
-  }, cb, Object.assign({}, options));
-};
-Store.prototype.replaceState = function replaceState(state) {
-  var this$1$1 = this;
-  this._withCommit(function() {
-    this$1$1._state.data = state;
-  });
-};
-Store.prototype.registerModule = function registerModule(path, rawModule, options) {
-  if (options === void 0)
-    options = {};
-  if (typeof path === "string") {
-    path = [path];
-  }
-  {
-    assert(Array.isArray(path), "module path must be a string or an Array.");
-    assert(path.length > 0, "cannot register the root module by using registerModule.");
-  }
-  this._modules.register(path, rawModule);
-  installModule(this, this.state, path, this._modules.get(path), options.preserveState);
-  resetStoreState(this, this.state);
-};
-Store.prototype.unregisterModule = function unregisterModule(path) {
-  var this$1$1 = this;
-  if (typeof path === "string") {
-    path = [path];
-  }
-  {
-    assert(Array.isArray(path), "module path must be a string or an Array.");
-  }
-  this._modules.unregister(path);
-  this._withCommit(function() {
-    var parentState = getNestedState(this$1$1.state, path.slice(0, -1));
-    delete parentState[path[path.length - 1]];
-  });
-  resetStore(this);
-};
-Store.prototype.hasModule = function hasModule(path) {
-  if (typeof path === "string") {
-    path = [path];
-  }
-  {
-    assert(Array.isArray(path), "module path must be a string or an Array.");
-  }
-  return this._modules.isRegistered(path);
-};
-Store.prototype.hotUpdate = function hotUpdate(newOptions) {
-  this._modules.update(newOptions);
-  resetStore(this, true);
-};
-Store.prototype._withCommit = function _withCommit(fn) {
-  var committing = this._committing;
-  this._committing = true;
-  fn();
-  this._committing = committing;
-};
-Object.defineProperties(Store.prototype, prototypeAccessors);
-const createHook = (lifecycle) => (hook, target = getCurrentInstance()) => {
-  !isInSSRComponentSetup && injectHook(lifecycle, hook, target);
-};
-const onShow = /* @__PURE__ */ createHook(ON_SHOW);
-const onLoad = /* @__PURE__ */ createHook(ON_LOAD);
-const onReady = /* @__PURE__ */ createHook(ON_READY);
-const onUnload = /* @__PURE__ */ createHook(ON_UNLOAD);
-const onNavigationBarButtonTap = /* @__PURE__ */ createHook(ON_NAVIGATION_BAR_BUTTON_TAP);
-var dayjs_min = { exports: {} };
-(function(module, exports2) {
-  !function(t2, e2) {
-    module.exports = e2();
-  }(commonjsGlobal, function() {
-    var t2 = 1e3, e2 = 6e4, n2 = 36e5, r = "millisecond", i = "second", s2 = "minute", u = "hour", a = "day", o2 = "week", f2 = "month", h = "quarter", c = "year", d = "date", l = "Invalid Date", $ = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/, y = /\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g, M = { name: "en", weekdays: "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), months: "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), ordinal: function(t3) {
-      var e3 = ["th", "st", "nd", "rd"], n3 = t3 % 100;
-      return "[" + t3 + (e3[(n3 - 20) % 10] || e3[n3] || e3[0]) + "]";
-    } }, m = function(t3, e3, n3) {
-      var r2 = String(t3);
-      return !r2 || r2.length >= e3 ? t3 : "" + Array(e3 + 1 - r2.length).join(n3) + t3;
-    }, v = { s: m, z: function(t3) {
-      var e3 = -t3.utcOffset(), n3 = Math.abs(e3), r2 = Math.floor(n3 / 60), i2 = n3 % 60;
-      return (e3 <= 0 ? "+" : "-") + m(r2, 2, "0") + ":" + m(i2, 2, "0");
-    }, m: function t3(e3, n3) {
-      if (e3.date() < n3.date())
-        return -t3(n3, e3);
-      var r2 = 12 * (n3.year() - e3.year()) + (n3.month() - e3.month()), i2 = e3.clone().add(r2, f2), s3 = n3 - i2 < 0, u2 = e3.clone().add(r2 + (s3 ? -1 : 1), f2);
-      return +(-(r2 + (n3 - i2) / (s3 ? i2 - u2 : u2 - i2)) || 0);
-    }, a: function(t3) {
-      return t3 < 0 ? Math.ceil(t3) || 0 : Math.floor(t3);
-    }, p: function(t3) {
-      return { M: f2, y: c, w: o2, d: a, D: d, h: u, m: s2, s: i, ms: r, Q: h }[t3] || String(t3 || "").toLowerCase().replace(/s$/, "");
-    }, u: function(t3) {
-      return t3 === void 0;
-    } }, g = "en", D = {};
-    D[g] = M;
-    var p2 = function(t3) {
-      return t3 instanceof _;
-    }, S = function t3(e3, n3, r2) {
-      var i2;
-      if (!e3)
-        return g;
-      if (typeof e3 == "string") {
-        var s3 = e3.toLowerCase();
-        D[s3] && (i2 = s3), n3 && (D[s3] = n3, i2 = s3);
-        var u2 = e3.split("-");
-        if (!i2 && u2.length > 1)
-          return t3(u2[0]);
-      } else {
-        var a2 = e3.name;
-        D[a2] = e3, i2 = a2;
-      }
-      return !r2 && i2 && (g = i2), i2 || !r2 && g;
-    }, w = function(t3, e3) {
-      if (p2(t3))
-        return t3.clone();
-      var n3 = typeof e3 == "object" ? e3 : {};
-      return n3.date = t3, n3.args = arguments, new _(n3);
-    }, O = v;
-    O.l = S, O.i = p2, O.w = function(t3, e3) {
-      return w(t3, { locale: e3.$L, utc: e3.$u, x: e3.$x, $offset: e3.$offset });
-    };
-    var _ = function() {
-      function M2(t3) {
-        this.$L = S(t3.locale, null, true), this.parse(t3);
-      }
-      var m2 = M2.prototype;
-      return m2.parse = function(t3) {
-        this.$d = function(t4) {
-          var e3 = t4.date, n3 = t4.utc;
-          if (e3 === null)
-            return new Date(NaN);
-          if (O.u(e3))
-            return new Date();
-          if (e3 instanceof Date)
-            return new Date(e3);
-          if (typeof e3 == "string" && !/Z$/i.test(e3)) {
-            var r2 = e3.match($);
-            if (r2) {
-              var i2 = r2[2] - 1 || 0, s3 = (r2[7] || "0").substring(0, 3);
-              return n3 ? new Date(Date.UTC(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s3)) : new Date(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s3);
-            }
-          }
-          return new Date(e3);
-        }(t3), this.$x = t3.x || {}, this.init();
-      }, m2.init = function() {
-        var t3 = this.$d;
-        this.$y = t3.getFullYear(), this.$M = t3.getMonth(), this.$D = t3.getDate(), this.$W = t3.getDay(), this.$H = t3.getHours(), this.$m = t3.getMinutes(), this.$s = t3.getSeconds(), this.$ms = t3.getMilliseconds();
-      }, m2.$utils = function() {
-        return O;
-      }, m2.isValid = function() {
-        return !(this.$d.toString() === l);
-      }, m2.isSame = function(t3, e3) {
-        var n3 = w(t3);
-        return this.startOf(e3) <= n3 && n3 <= this.endOf(e3);
-      }, m2.isAfter = function(t3, e3) {
-        return w(t3) < this.startOf(e3);
-      }, m2.isBefore = function(t3, e3) {
-        return this.endOf(e3) < w(t3);
-      }, m2.$g = function(t3, e3, n3) {
-        return O.u(t3) ? this[e3] : this.set(n3, t3);
-      }, m2.unix = function() {
-        return Math.floor(this.valueOf() / 1e3);
-      }, m2.valueOf = function() {
-        return this.$d.getTime();
-      }, m2.startOf = function(t3, e3) {
-        var n3 = this, r2 = !!O.u(e3) || e3, h2 = O.p(t3), l2 = function(t4, e4) {
-          var i2 = O.w(n3.$u ? Date.UTC(n3.$y, e4, t4) : new Date(n3.$y, e4, t4), n3);
-          return r2 ? i2 : i2.endOf(a);
-        }, $2 = function(t4, e4) {
-          return O.w(n3.toDate()[t4].apply(n3.toDate("s"), (r2 ? [0, 0, 0, 0] : [23, 59, 59, 999]).slice(e4)), n3);
-        }, y2 = this.$W, M3 = this.$M, m3 = this.$D, v2 = "set" + (this.$u ? "UTC" : "");
-        switch (h2) {
-          case c:
-            return r2 ? l2(1, 0) : l2(31, 11);
-          case f2:
-            return r2 ? l2(1, M3) : l2(0, M3 + 1);
-          case o2:
-            var g2 = this.$locale().weekStart || 0, D2 = (y2 < g2 ? y2 + 7 : y2) - g2;
-            return l2(r2 ? m3 - D2 : m3 + (6 - D2), M3);
-          case a:
-          case d:
-            return $2(v2 + "Hours", 0);
-          case u:
-            return $2(v2 + "Minutes", 1);
-          case s2:
-            return $2(v2 + "Seconds", 2);
-          case i:
-            return $2(v2 + "Milliseconds", 3);
-          default:
-            return this.clone();
-        }
-      }, m2.endOf = function(t3) {
-        return this.startOf(t3, false);
-      }, m2.$set = function(t3, e3) {
-        var n3, o3 = O.p(t3), h2 = "set" + (this.$u ? "UTC" : ""), l2 = (n3 = {}, n3[a] = h2 + "Date", n3[d] = h2 + "Date", n3[f2] = h2 + "Month", n3[c] = h2 + "FullYear", n3[u] = h2 + "Hours", n3[s2] = h2 + "Minutes", n3[i] = h2 + "Seconds", n3[r] = h2 + "Milliseconds", n3)[o3], $2 = o3 === a ? this.$D + (e3 - this.$W) : e3;
-        if (o3 === f2 || o3 === c) {
-          var y2 = this.clone().set(d, 1);
-          y2.$d[l2]($2), y2.init(), this.$d = y2.set(d, Math.min(this.$D, y2.daysInMonth())).$d;
-        } else
-          l2 && this.$d[l2]($2);
-        return this.init(), this;
-      }, m2.set = function(t3, e3) {
-        return this.clone().$set(t3, e3);
-      }, m2.get = function(t3) {
-        return this[O.p(t3)]();
-      }, m2.add = function(r2, h2) {
-        var d2, l2 = this;
-        r2 = Number(r2);
-        var $2 = O.p(h2), y2 = function(t3) {
-          var e3 = w(l2);
-          return O.w(e3.date(e3.date() + Math.round(t3 * r2)), l2);
-        };
-        if ($2 === f2)
-          return this.set(f2, this.$M + r2);
-        if ($2 === c)
-          return this.set(c, this.$y + r2);
-        if ($2 === a)
-          return y2(1);
-        if ($2 === o2)
-          return y2(7);
-        var M3 = (d2 = {}, d2[s2] = e2, d2[u] = n2, d2[i] = t2, d2)[$2] || 1, m3 = this.$d.getTime() + r2 * M3;
-        return O.w(m3, this);
-      }, m2.subtract = function(t3, e3) {
-        return this.add(-1 * t3, e3);
-      }, m2.format = function(t3) {
-        var e3 = this, n3 = this.$locale();
-        if (!this.isValid())
-          return n3.invalidDate || l;
-        var r2 = t3 || "YYYY-MM-DDTHH:mm:ssZ", i2 = O.z(this), s3 = this.$H, u2 = this.$m, a2 = this.$M, o3 = n3.weekdays, f3 = n3.months, h2 = function(t4, n4, i3, s4) {
-          return t4 && (t4[n4] || t4(e3, r2)) || i3[n4].slice(0, s4);
-        }, c2 = function(t4) {
-          return O.s(s3 % 12 || 12, t4, "0");
-        }, d2 = n3.meridiem || function(t4, e4, n4) {
-          var r3 = t4 < 12 ? "AM" : "PM";
-          return n4 ? r3.toLowerCase() : r3;
-        }, $2 = { YY: String(this.$y).slice(-2), YYYY: O.s(this.$y, 4, "0"), M: a2 + 1, MM: O.s(a2 + 1, 2, "0"), MMM: h2(n3.monthsShort, a2, f3, 3), MMMM: h2(f3, a2), D: this.$D, DD: O.s(this.$D, 2, "0"), d: String(this.$W), dd: h2(n3.weekdaysMin, this.$W, o3, 2), ddd: h2(n3.weekdaysShort, this.$W, o3, 3), dddd: o3[this.$W], H: String(s3), HH: O.s(s3, 2, "0"), h: c2(1), hh: c2(2), a: d2(s3, u2, true), A: d2(s3, u2, false), m: String(u2), mm: O.s(u2, 2, "0"), s: String(this.$s), ss: O.s(this.$s, 2, "0"), SSS: O.s(this.$ms, 3, "0"), Z: i2 };
-        return r2.replace(y, function(t4, e4) {
-          return e4 || $2[t4] || i2.replace(":", "");
-        });
-      }, m2.utcOffset = function() {
-        return 15 * -Math.round(this.$d.getTimezoneOffset() / 15);
-      }, m2.diff = function(r2, d2, l2) {
-        var $2, y2 = O.p(d2), M3 = w(r2), m3 = (M3.utcOffset() - this.utcOffset()) * e2, v2 = this - M3, g2 = O.m(this, M3);
-        return g2 = ($2 = {}, $2[c] = g2 / 12, $2[f2] = g2, $2[h] = g2 / 3, $2[o2] = (v2 - m3) / 6048e5, $2[a] = (v2 - m3) / 864e5, $2[u] = v2 / n2, $2[s2] = v2 / e2, $2[i] = v2 / t2, $2)[y2] || v2, l2 ? g2 : O.a(g2);
-      }, m2.daysInMonth = function() {
-        return this.endOf(f2).$D;
-      }, m2.$locale = function() {
-        return D[this.$L];
-      }, m2.locale = function(t3, e3) {
-        if (!t3)
-          return this.$L;
-        var n3 = this.clone(), r2 = S(t3, e3, true);
-        return r2 && (n3.$L = r2), n3;
-      }, m2.clone = function() {
-        return O.w(this.$d, this);
-      }, m2.toDate = function() {
-        return new Date(this.valueOf());
-      }, m2.toJSON = function() {
-        return this.isValid() ? this.toISOString() : null;
-      }, m2.toISOString = function() {
-        return this.$d.toISOString();
-      }, m2.toString = function() {
-        return this.$d.toUTCString();
-      }, M2;
-    }(), T = _.prototype;
-    return w.prototype = T, [["$ms", r], ["$s", i], ["$m", s2], ["$H", u], ["$W", a], ["$M", f2], ["$y", c], ["$D", d]].forEach(function(t3) {
-      T[t3[1]] = function(e3) {
-        return this.$g(e3, t3[0], t3[1]);
-      };
-    }), w.extend = function(t3, e3) {
-      return t3.$i || (t3(e3, _, w), t3.$i = true), w;
-    }, w.locale = S, w.isDayjs = p2, w.unix = function(t3) {
-      return w(1e3 * t3);
-    }, w.en = D[g], w.Ls = D, w.p = {}, w;
-  });
-})(dayjs_min);
-var dayjs = dayjs_min.exports;
-exports.TIMUploadPlugin = TIMUploadPlugin;
-exports._export_sfc = _export_sfc;
-exports.computed$1 = computed$1;
-exports.createSSRApp = createSSRApp;
-exports.createStore = createStore;
-exports.dayjs = dayjs;
-exports.defineComponent = defineComponent;
-exports.e = e;
-exports.f = f;
-exports.index = index;
-exports.n = n;
-exports.nextTick = nextTick;
-exports.o = o;
-exports.onLoad = onLoad;
-exports.onMounted = onMounted;
-exports.onNavigationBarButtonTap = onNavigationBarButtonTap;
-exports.onReady = onReady;
-exports.onShow = onShow;
-exports.onUnload = onUnload;
-exports.p = p;
-exports.reactive = reactive;
-exports.ref = ref;
-exports.resolveComponent = resolveComponent;
-exports.s = s;
-exports.shallowRef = shallowRef;
-exports.sr = sr;
-exports.t = t;
-exports.toRefs = toRefs;
-exports.watch = watch;
-exports.watchEffect = watchEffect;

+ 0 - 71
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.js

@@ -1,71 +0,0 @@
-"use strict";
-var common_vendor = require("../../../common/vendor.js");
-var api_healthTongue = require("../../../api/healthTongue.js");
-require("../../../common/request.js");
-const _sfc_main = {
-  data() {
-    return {
-      baseUrl: common_vendor.index.getStorageSync("requestPath"),
-      cameraHeight: "",
-      optionsHeight: "",
-      counts: 0,
-      url: null
-    };
-  },
-  onLoad() {
-    this.getCount();
-  },
-  methods: {
-    switchCamera() {
-      this.$emit("switchCamera");
-    },
-    getCount() {
-      api_healthTongue.getCount().then((res) => {
-        if (res.code == 200) {
-          this.counts = res.data;
-        } else {
-          common_vendor.index.showToast({
-            icon: "none",
-            title: "\u8BF7\u6C42\u5931\u8D25"
-          });
-        }
-      }, (rej) => {
-      });
-    },
-    takePhoto() {
-      const ctx = wx.createCameraContext();
-      console.log("ctx", ctx);
-      ctx.takePhoto({
-        quality: "high",
-        success: (res) => {
-          common_vendor.index.setStorageSync("tongueUrl", res.tempImagePath);
-          console.log("res", res.tempImagePath);
-          this.$emit("takePhoto");
-        }
-      });
-    },
-    handleClikFn(instruct) {
-      this.$emit("instruct", instruct);
-    }
-  },
-  mounted() {
-    const query = common_vendor.index.createSelectorQuery().in(this);
-    query.select("#camera-footer").boundingClientRect((data) => {
-      this.cameraHeight = common_vendor.index.getSystemInfoSync().screenHeight - data.height;
-    }).exec();
-  }
-};
-function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
-  return {
-    a: $data.cameraHeight + "px",
-    b: common_vendor.t($data.counts || 0),
-    c: $data.baseUrl + "/images/album_icon.png",
-    d: common_vendor.o(($event) => $options.handleClikFn("album")),
-    e: common_vendor.o(($event) => $options.takePhoto()),
-    f: $data.baseUrl + "/images/tongue_info.png",
-    g: common_vendor.o(($event) => $options.handleClikFn("reportlist")),
-    h: common_vendor.o(($event) => $options.switchCamera())
-  };
-}
-var Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-0404ee55"], ["__file", "E:/Project/2023/\u95EE\u8BCA\u5E73\u53F0/his_user_miniapp/components/CustomCamera/WeChat/Layout.vue"]]);
-wx.createComponent(Component);

+ 0 - 4
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.json

@@ -1,4 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {}
-}

+ 0 - 1
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.wxml

@@ -1 +0,0 @@
-<view class="custom-camera data-v-0404ee55"><view class="camera-wrap data-v-0404ee55" style="{{'height:' + a}}"><slot></slot></view><view class="camera-footer data-v-0404ee55" id="camera-footer"><view class="usenum data-v-0404ee55">当前可免费试用<text class="data-v-0404ee55" style="color:#F54D04;margin:0 6rpx">{{b}}</text>次</view><view class="camera-options data-v-0404ee55"><view class="camera-options-left camera-item data-v-0404ee55"><image class="data-v-0404ee55" src="{{c}}" mode="scaleToFill" style="width:65rpx;height:60rpx" bindtap="{{d}}"></image><text class="data-v-0404ee55">相册上传</text></view><view class="camera-options-center camera-item data-v-0404ee55" bindtap="{{e}}"><view class="photograph-btn data-v-0404ee55"></view></view><view class="camera-options-ritht camera-item data-v-0404ee55" bindtap="{{h}}"><image class="data-v-0404ee55" src="{{f}}" mode="scaleToFill" style="width:67rpx;height:60rpx" bindtap="{{g}}"></image><text class="data-v-0404ee55">切换摄像头</text></view></view></view></view>

+ 0 - 73
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/Layout.wxss

@@ -1,73 +0,0 @@
-/**
- * 这里是uni-app内置的常用样式变量
- *
- * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
- * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
- *
- */
-/**
- * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
- *
- * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
- */
-/* 颜色变量 */
-/* 行为相关颜色 */
-/* 文字基本颜色 */
-/* 背景颜色 */
-/* 边框颜色 */
-/* 尺寸变量 */
-/* 文字尺寸 */
-/* 图片尺寸 */
-/* Border Radius */
-/* 水平间距 */
-/* 垂直间距 */
-/* 透明度 */
-/* 文章场景相关 */
-.custom-camera.data-v-0404ee55 {
-  height: 100vh;
-  background-color: #000;
-}
-.custom-camera .usenum.data-v-0404ee55 {
-  font-family: SourceHanSansCN;
-  font-weight: 400;
-  font-size: 24rpx;
-  color: #FFFFFF;
-  padding: 14rpx;
-  text-align: center;
-}
-.custom-camera .camera-options.data-v-0404ee55 {
-  width: 100%;
-  padding-top: 13rpx;
-  padding-bottom: 60rpx;
-  box-sizing: border-box;
-  font-family: SourceHanSansCN;
-  font-weight: 400;
-  font-size: 27rpx;
-  color: #FFFFFF;
-  display: flex;
-  align-items: center;
-  justify-content: space-evenly;
-}
-.custom-camera .camera-options .camera-item.data-v-0404ee55 {
-  display: flex;
-  flex-direction: column;
-  align-items: center;
-}
-.custom-camera .camera-options .camera-item image.data-v-0404ee55 {
-  margin-bottom: 21rpx;
-}
-.custom-camera .camera-options .camera-options-center.data-v-0404ee55 {
-  width: 131rpx;
-  height: 131rpx;
-  border-radius: 50%;
-  border: 3px solid #FFFFFF;
-  display: flex;
-  align-items: center;
-  justify-content: center;
-}
-.custom-camera .camera-options .photograph-btn.data-v-0404ee55 {
-  width: 109rpx;
-  height: 109rpx;
-  background: #F54D04;
-  border-radius: 50%;
-}

+ 0 - 94
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.js

@@ -1,94 +0,0 @@
-"use strict";
-var common_vendor = require("../../../common/vendor.js");
-const Layout = () => "./Layout.js";
-const _sfc_main = {
-  components: {
-    Layout
-  },
-  data() {
-    return {
-      baseUrl: common_vendor.index.getStorageSync("requestPath"),
-      statusBarHeight: common_vendor.index.getSystemInfoSync().statusBarHeight + "px",
-      device: "back",
-      cameraContext: null,
-      shutterShow: false,
-      coverImage: null,
-      menuLeft: "100%"
-    };
-  },
-  mounted() {
-    common_vendor.index.getSystemInfo({
-      success: (result) => {
-        const menuButtonInfo = common_vendor.index.getMenuButtonBoundingClientRect();
-        this.menuLeft = menuButtonInfo.left + "px";
-      },
-      fail: (error) => {
-        console.log(error);
-      }
-    });
-    this.cameraContext = common_vendor.index.createCameraContext();
-  },
-  methods: {
-    switchCamera() {
-      this.device = this.device === "back" ? "front" : "back";
-    },
-    back() {
-      common_vendor.index.navigateBack();
-    },
-    error(err) {
-      console.log(err);
-    },
-    takePhoto() {
-      this.$emit("takePhoto");
-    },
-    handleInstruct(instruct) {
-      switch (instruct) {
-        case "back":
-          this.$emit("back");
-          break;
-        case "shutter":
-          this.cameraContext.takePhoto({
-            quality: "high",
-            success: (res) => {
-              this.$emit("getImage", res.tempImagePath);
-            }
-          });
-          break;
-        case "reversal":
-          this.device = this.device === "back" ? "front" : "back";
-          break;
-        case "album":
-          common_vendor.index.chooseImage({
-            count: 1,
-            sizeType: ["original", "compressed"],
-            sourceType: ["album"],
-            success: (res) => {
-              common_vendor.index.setStorageSync("tongueUrl", res.tempFilePaths[0]);
-              this.$emit("getImage");
-            }
-          });
-          break;
-      }
-    }
-  }
-};
-if (!Array) {
-  const _component_Layout = common_vendor.resolveComponent("Layout");
-  _component_Layout();
-}
-function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
-  return {
-    a: $data.statusBarHeight,
-    b: common_vendor.o((...args) => $options.back && $options.back(...args)),
-    c: $data.baseUrl + "/images/ques.png",
-    d: $data.menuLeft,
-    e: $data.baseUrl + "/images/tongue.png",
-    f: $data.device,
-    g: common_vendor.o((...args) => $options.error && $options.error(...args)),
-    h: common_vendor.o($options.handleInstruct),
-    i: common_vendor.o(($event) => $options.switchCamera()),
-    j: common_vendor.o($options.takePhoto)
-  };
-}
-var Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-4814c2d2"], ["__file", "E:/Project/2023/\u95EE\u8BCA\u5E73\u53F0/his_user_miniapp/components/CustomCamera/WeChat/index.vue"]]);
-wx.createComponent(Component);

+ 0 - 6
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.json

@@ -1,6 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {
-    "layout": "./Layout"
-  }
-}

+ 0 - 1
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.wxml

@@ -1 +0,0 @@
-<layout class="data-v-4814c2d2" u-s="{{['d']}}" bindinstruct="{{h}}" bindswitchCamera="{{i}}" bindtakePhoto="{{j}}" u-i="4814c2d2-0" bind:__l="__l"><camera class="camera data-v-4814c2d2" mode="normal" device-position="{{f}}" binderror="{{g}}" style="width:100%;height:100%"><cover-view class="cover-view data-v-4814c2d2"><cover-view class="uni-nav-bar data-v-4814c2d2"><cover-view class="data-v-4814c2d2" style="{{'height:' + a + ';' + ('width:' + '100%')}}"></cover-view><cover-view class="uni-nav-barbox data-v-4814c2d2" style="{{'width:' + d}}"><cover-view class="uni-nav-back data-v-4814c2d2" bindtap="{{b}}">返回 </cover-view><cover-view class="uni-nav-title data-v-4814c2d2"><cover-view class="data-v-4814c2d2">使用教程</cover-view><cover-image class="ques data-v-4814c2d2" src="{{c}}" mode="aspectFill"></cover-image></cover-view></cover-view></cover-view><cover-view class="title data-v-4814c2d2">请拍摄舌面</cover-view><cover-view class="tips data-v-4814c2d2">舌尖放松,舌面平展,舌尖略向下,口张大不要太用力</cover-view><cover-view class="imagebox data-v-4814c2d2"><cover-image class="tongue data-v-4814c2d2" src="{{e}}" mode="aspectFill"></cover-image></cover-view></cover-view></camera></layout>

+ 0 - 110
unpackage/dist/dev/mp-weixin/components/CustomCamera/WeChat/index.wxss

@@ -1,110 +0,0 @@
-/**
- * 这里是uni-app内置的常用样式变量
- *
- * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
- * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
- *
- */
-/**
- * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
- *
- * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
- */
-/* 颜色变量 */
-/* 行为相关颜色 */
-/* 文字基本颜色 */
-/* 背景颜色 */
-/* 边框颜色 */
-/* 尺寸变量 */
-/* 文字尺寸 */
-/* 图片尺寸 */
-/* Border Radius */
-/* 水平间距 */
-/* 垂直间距 */
-/* 透明度 */
-/* 文章场景相关 */
-.imagebox.data-v-4814c2d2 {
-  width: 100%;
-  margin-top: 30rpx;
-  display: flex;
-  flex-direction: column;
-  align-items: center;
-  justify-content: center;
-}
-.tongue.data-v-4814c2d2 {
-  width: 531rpx;
-  height: 592rpx;
-  margin: 0 auto;
-  margin-top: 30rpx;
-}
-.cover-view.data-v-4814c2d2 {
-  width: 100%;
-  position: absolute;
-  z-index: 99;
-  top: 0;
-  left: 0;
-}
-.title.data-v-4814c2d2 {
-  margin-top: calc(var(--status-bar-height) + 130rpx);
-  font-family: SourceHanSansCN-Medium;
-  font-weight: 500;
-  font-size: 43rpx;
-  color: #FFFFFF;
-  text-align: center;
-}
-.tips.data-v-4814c2d2 {
-  margin-top: 38rpx;
-  font-family: SourceHanSansSC-Regular;
-  font-weight: 400;
-  font-size: 24rpx;
-  color: #FFFFFF;
-  text-align: center;
-}
-.uni-nav-bar.data-v-4814c2d2 {
-  position: fixed;
-  top: 0;
-  left: 0;
-  width: 100%;
-  z-index: 999;
-  overflow: hidden;
-  font-family: PingFang SC, PingFang SC;
-  font-weight: 500;
-  color: #FFFFFF;
-}
-.uni-nav-bar .uni-nav-barbox.data-v-4814c2d2 {
-  width: 100%;
-  height: 88rpx;
-  padding: 0 24rpx;
-  box-sizing: border-box;
-  display: flex;
-  flex-direction: row;
-  align-items: center;
-  justify-content: space-between;
-  position: relative;
-  font-size: 32rpx;
-}
-.uni-nav-bar .uni-nav-title.data-v-4814c2d2 {
-  flex-shrink: 0;
-  font-family: SourceHanSansSC;
-  font-weight: 400;
-  color: #FFFFFF;
-  font-size: 32rpx;
-  display: flex;
-  flex-direction: row;
-  align-items: center;
-  justify-content: flex-start;
-}
-.uni-nav-bar .uni-nav-title .ques.data-v-4814c2d2 {
-  flex-shrink: 0;
-  width: 33rpx;
-  height: 33rpx;
-  margin-left: 9rpx;
-}
-.uni-nav-bar .uni-nav-back.data-v-4814c2d2 {
-  width: 100%;
-  height: 88rpx;
-  line-height: 88rpx;
-}
-.camera.data-v-4814c2d2 {
-  position: relative;
-}

+ 0 - 20
unpackage/dist/dev/mp-weixin/components/Loading.js

@@ -1,20 +0,0 @@
-"use strict";
-var common_vendor = require("../common/vendor.js");
-const _sfc_main = {
-  name: "Loading",
-  props: {
-    loaded: Boolean,
-    loading: Boolean
-  }
-};
-function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
-  return common_vendor.e({
-    a: $props.loading || !$props.loaded
-  }, $props.loading || !$props.loaded ? common_vendor.e({
-    b: $props.loading
-  }, $props.loading ? {} : {}, {
-    c: !$props.loading
-  }, !$props.loading ? {} : {}) : {});
-}
-var Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render], ["__file", "E:/Project/2023/\u95EE\u8BCA\u5E73\u53F0/his_user_miniapp/components/Loading.vue"]]);
-wx.createComponent(Component);

+ 0 - 4
unpackage/dist/dev/mp-weixin/components/Loading.json

@@ -1,4 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {}
-}

+ 0 - 1
unpackage/dist/dev/mp-weixin/components/Loading.wxml

@@ -1 +0,0 @@
-<view wx:if="{{a}}" class="Loads acea-row row-center-wrapper" style="margin-top:20rpx"><block wx:if="{{b}}"><view class="iconfont icon-jiazai loading acea-row row-center-wrapper"></view> 正在加载中 </block><block wx:if="{{c}}"> 上拉加载更多 </block></view>

+ 0 - 26
unpackage/dist/dev/mp-weixin/components/Loading.wxss

@@ -1,26 +0,0 @@
-.Loads {
-  height: 80rpx;
-  font-size: 25rpx;
-  color: #000;
-}
-.Loads .iconfont {
-  font-size: 30rpx;
-  margin-right: 10rpx;
-  height: 32rpx;
-  line-height: 32rpx;
-}
-/*加载动画*/
-@keyframes load {
-from {
-    transform: rotate(0deg);
-}
-to {
-    transform: rotate(360deg);
-}
-}
-.loadingpic {
-  animation: load 3s linear 1s infinite;
-}
-.loading {
-  animation: load linear 1s infinite;
-}

+ 0 - 94
unpackage/dist/dev/mp-weixin/components/Menu.js

@@ -1,94 +0,0 @@
-"use strict";
-var common_vendor = require("../common/vendor.js");
-const _sfc_main = {
-  components: {},
-  data() {
-    return {
-      cateId: 0,
-      menuCurrent: 0
-    };
-  },
-  props: {
-    list: {
-      type: Array,
-      default: []
-    },
-    menu: {
-      default: 4
-    },
-    imgW: {
-      type: Number,
-      default: 88
-    }
-  },
-  computed: {
-    carousel() {
-      if (this.list) {
-        let data = this.sortData(this.list, this.menu * 2);
-        return data;
-      }
-    }
-  },
-  created() {
-  },
-  methods: {
-    sortData(oArr, length) {
-      let arr = [];
-      let minArr = [];
-      oArr.forEach((c) => {
-        if (minArr.length === length) {
-          minArr = [];
-        }
-        if (minArr.length === 0) {
-          arr.push(minArr);
-        }
-        minArr.push(c);
-      });
-      return arr;
-    },
-    onSwiper(e) {
-      this.menuCurrent = e.detail.current;
-    },
-    routerTo(item) {
-      this.cateId = item.cateId;
-      this.$emit("menuClick", item);
-    }
-  }
-};
-function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
-  return common_vendor.e({
-    a: $options.carousel
-  }, $options.carousel ? common_vendor.e({
-    b: common_vendor.f($options.carousel, (itemList, index, i0) => {
-      return {
-        a: common_vendor.f(itemList, (item, k1, i1) => {
-          return {
-            a: item.imgUrl,
-            b: common_vendor.t(item.cateName),
-            c: common_vendor.n($data.cateId == item.cateId ? "tab-title active" : "tab-title"),
-            d: item.cateId,
-            e: common_vendor.o(($event) => $options.routerTo(item), item.cateId)
-          };
-        }),
-        b: index
-      };
-    }),
-    c: $props.imgW + "rpx",
-    d: $props.imgW + "rpx",
-    e: common_vendor.s($props.list.length <= $props.menu ? `height:200rpx` : `height:340rpx`),
-    f: common_vendor.s($props.list.length <= $props.menu ? `height:160rpx` : `height:320rpx`),
-    g: common_vendor.o((...args) => $options.onSwiper && $options.onSwiper(...args)),
-    h: $options.carousel.length > 1
-  }, $options.carousel.length > 1 ? {
-    i: common_vendor.f($options.carousel.length, (dot, index, i0) => {
-      return {
-        a: common_vendor.n($data.menuCurrent === index ? "dot-active" : "dot"),
-        b: index
-      };
-    })
-  } : {}, {
-    j: common_vendor.s($props.list.length <= $props.menu ? `height:160rpx` : `height:320rpx`)
-  }) : {});
-}
-var Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["render", _sfc_render], ["__file", "E:/Project/2023/\u95EE\u8BCA\u5E73\u53F0/his_user_miniapp/components/Menu.vue"]]);
-wx.createComponent(Component);

+ 0 - 4
unpackage/dist/dev/mp-weixin/components/Menu.json

@@ -1,4 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {}
-}

+ 0 - 1
unpackage/dist/dev/mp-weixin/components/Menu.wxml

@@ -1 +0,0 @@
-<view wx:if="{{a}}" class="menu-list-box" style="{{j}}"><swiper class="menu-swiper-box" style="{{f}}" bindchange="{{g}}" circular autoplay="{{false}}" interval="{{3000}}" duration="{{1000}}"><swiper-item wx:for="{{b}}" wx:for-item="itemList" wx:key="b" class="menu-swiper-item" style="{{e}}"><view class="menu-tab-box"><view wx:for="{{itemList.a}}" wx:for-item="item" wx:key="d" class="tab-list" bindtap="{{item.e}}"><image class="tab-img" style="{{'width:' + c + ';' + ('height:' + d)}}" src="{{item.a}}"></image><text class="{{item.c}}">{{item.b}}</text></view></view></swiper-item></swiper><view wx:if="{{h}}" class="menu-dots"><text wx:for="{{i}}" wx:for-item="dot" wx:key="b" class="{{dot.a}}"></text></view></view>

+ 0 - 96
unpackage/dist/dev/mp-weixin/components/Menu.wxss

@@ -1,96 +0,0 @@
-/**
- * 这里是uni-app内置的常用样式变量
- *
- * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
- * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
- *
- */
-/**
- * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
- *
- * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
- */
-/* 颜色变量 */
-/* 行为相关颜色 */
-/* 文字基本颜色 */
-/* 背景颜色 */
-/* 边框颜色 */
-/* 尺寸变量 */
-/* 文字尺寸 */
-/* 图片尺寸 */
-/* Border Radius */
-/* 水平间距 */
-/* 垂直间距 */
-/* 透明度 */
-/* 文章场景相关 */
-.menu-list-box {
-  padding: 0rpx;
-  background: #fff;
-  box-sizing: border-box;
-}
-.menu-list-box,
-.menu-swiper-box {
-  position: relative;
-  background: #fff;
-}
-.menu-list-box .menu-swiper-item,
-.menu-swiper-box .menu-swiper-item {
-  background: #fff;
-  height: 100%;
-  width: 100%;
-}
-.menu-list-box .menu-tab-box,
-.menu-swiper-box .menu-tab-box {
-  display: flex;
-  flex-wrap: wrap;
-}
-.menu-list-box .menu-tab-box .tab-list,
-.menu-swiper-box .menu-tab-box .tab-list {
-  width: 25%;
-  display: flex;
-  flex-direction: column;
-  align-items: center;
-  font-size: 22rpx;
-  font-family: PingFang SC;
-  font-weight: 500;
-  color: #333333;
-  padding-bottom: 30rpx;
-}
-.menu-list-box .menu-tab-box .tab-list .tab-img,
-.menu-swiper-box .menu-tab-box .tab-list .tab-img {
-  border-radius: 25rpx;
-  margin-bottom: 10rpx;
-}
-.menu-list-box .menu-tab-box .tab-list .tab-title,
-.menu-swiper-box .menu-tab-box .tab-list .tab-title {
-  font-size: 24rpx;
-  font-family: PingFang SC;
-  font-weight: 500;
-  color: #111;
-  margin-top: 10rpx;
-}
-.menu-list-box .menu-tab-box .tab-list .active,
-.menu-swiper-box .menu-tab-box .tab-list .active {
-  color: #E2C99E;
-}
-.menu-list-box .menu-dots,
-.menu-swiper-box .menu-dots {
-  display: flex;
-  position: absolute;
-  left: 50%;
-  transform: translateX(-50%);
-}
-.menu-list-box .menu-dots .dot,
-.menu-swiper-box .menu-dots .dot {
-  width: 40rpx;
-  height: 3rpx;
-  background: #eeeeee;
-  margin-right: 10rpx;
-}
-.menu-list-box .menu-dots .dot-active,
-.menu-swiper-box .menu-dots .dot-active {
-  width: 40rpx;
-  height: 3rpx;
-  background: #2BC7B9;
-  margin-right: 10rpx;
-}

+ 0 - 13
unpackage/dist/dev/mp-weixin/miniprogram_npm/@tencentcloud/call-uikit-wechat/index.js

@@ -1,13 +0,0 @@
-module.exports = (function() {
-var __MODS__ = {};
-var __DEFINE__ = function(modId, func, req) { var m = { exports: {}, _tempexports: {} }; __MODS__[modId] = { status: 0, func: func, req: req, m: m }; };
-var __REQUIRE__ = function(modId, source) { if(!__MODS__[modId]) return require(source); if(!__MODS__[modId].status) { var m = __MODS__[modId].m; m._exports = m._tempexports; var desp = Object.getOwnPropertyDescriptor(m, "exports"); if (desp && desp.configurable) Object.defineProperty(m, "exports", { set: function (val) { if(typeof val === "object" && val !== m._exports) { m._exports.__proto__ = val.__proto__; Object.keys(val).forEach(function (k) { m._exports[k] = val[k]; }); } m._tempexports = val }, get: function () { return m._tempexports; } }); __MODS__[modId].status = 1; __MODS__[modId].func(__MODS__[modId].req, m, m.exports); } return __MODS__[modId].m.exports; };
-var __REQUIRE_WILDCARD__ = function(obj) { if(obj && obj.__esModule) { return obj; } else { var newObj = {}; if(obj != null) { for(var k in obj) { if (Object.prototype.hasOwnProperty.call(obj, k)) newObj[k] = obj[k]; } } newObj.default = obj; return newObj; } };
-var __REQUIRE_DEFAULT__ = function(obj) { return obj && obj.__esModule ? obj.default : obj; };
-__DEFINE__(1742795809077, function(require, module, exports) {
-
-}, function(modId) {var map = {}; return __REQUIRE__(map[modId], modId); })
-return __REQUIRE__(1742795809077);
-})()
-//miniprogram-npm-outsideDeps=[]
-//# sourceMappingURL=index.js.map

+ 0 - 1
unpackage/dist/dev/mp-weixin/miniprogram_npm/@tencentcloud/call-uikit-wechat/index.js.map

@@ -1 +0,0 @@
-{"version":3,"sources":["index.js"],"names":[],"mappings":";;;;;;;AAAA","file":"index.js","sourcesContent":[""]}

File diff suppressed because it is too large
+ 0 - 7
unpackage/dist/dev/mp-weixin/miniprogram_npm/tim-wx-sdk/index.js


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/dev/mp-weixin/miniprogram_npm/tim-wx-sdk/index.js.map


File diff suppressed because it is too large
+ 0 - 7
unpackage/dist/dev/mp-weixin/miniprogram_npm/trtc-wx-sdk/index.js


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/dev/mp-weixin/miniprogram_npm/trtc-wx-sdk/index.js.map


File diff suppressed because it is too large
+ 0 - 7
unpackage/dist/dev/mp-weixin/miniprogram_npm/tsignaling-wx/index.js


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/dev/mp-weixin/miniprogram_npm/tsignaling-wx/index.js.map


File diff suppressed because it is too large
+ 0 - 7
unpackage/dist/dev/mp-weixin/miniprogram_npm/tuicall-engine-wx/index.js


File diff suppressed because it is too large
+ 0 - 0
unpackage/dist/dev/mp-weixin/miniprogram_npm/tuicall-engine-wx/index.js.map


+ 0 - 50
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/README.md

@@ -1,50 +0,0 @@
-# TUICallkit 组件接入说明
-TUICallkit 是小程序音视频通话 UI 组件,通过编写几行代码,就可以为您的小程序应用添加音视频通话功能。
-
-## 环境准备
-
-- 微信 App iOS 最低版本要求:7.0.9
-- 微信 App Android 最低版本要求:7.0.8
-- 小程序基础库最低版本要求:2.10.0
-- 由于小程序测试号不具备 live-pusher 和 live-player 的使用权限,请使用企业小程序账号申请相关权限进行开发
-- 由于微信开发者工具不支持原生组件(即 live-pusher 和 live-player 标签),需要在真机上进行运行体验
-
-## 特性
-- ⚡️ 功能全面 —— 支持单人/多人/音频/视频通话、支持视频转音频通话、支持自由选择通话设备
-- 🎨 灵活样式 —— 组件开源,可复用逻辑,自定义 UI 样式
-- 🛠 优秀生态 —— 与 [TUIKit](https://cloud.tencent.com/document/product/269/79737) 协同使用,可以在 [TIM](https://cloud.tencent.com/document/product/269) 会话中直接发起音视频通话
-- 🌍 跨平台 —— 支持 Android、iOS、Web、小程序、Flutter、UniApp 等 [多个开发平台](https://cloud.tencent.com/document/product/647/78742)
-- ☁️ 低延迟 —— 腾讯云全球链路资源储备,保证国际链路端到端平均时延 < 300ms
-- 🤙🏻 低卡顿 —— 抗丢包率超过 80%、抗网络抖动超过 1000ms,弱网环境仍顺畅稳定
-- 🌈 高品质 —— 支持 720P、1080P 高清画质,70% 丢包率仍可正常视频
-
-
-## 目录结构
-
-```
-TUICallkit
-├─ component             // UI 组件
-    ├─ calling           // 呼叫中 UI 组件(1v1通话)
-    └─ connected         // 通话中 UI 组件(1v1通话)
-    ├─ groupCalling      // 呼叫中 UI 组件(群组通话)
-    └─ groupConnected    // 通话中 UI 组件(群组通话)
-├─ pages                 
-    ├─ globalCall        // 全局监听页面
-├─ serve                 
-    ├─ callManager       // 全局监听类
-├─ static                // UI icon 图片
-```
-
-
-## 使用指引
-为方便您的使用,本组件配套多篇使用指引:
-- 如果您想要了解 TUICallKit,请阅读 [组件介绍 TUICallKit](https://cloud.tencent.com/document/product/647/78742)。
-- 如果您想把我们的功能直接嵌入到您的项目中,请阅读 [快速接入 TUICallKit](https://cloud.tencent.com/document/product/647/78733)。
-- 如果您想要了解详细 API,请阅读 [API 概览](https://cloud.tencent.com/document/product/647/78759)。
-
-## 附录
-
-- 如果你遇到了困难,可以先参阅 [常见问题](https://cloud.tencent.com/document/product/647/78733)。
-- 如果发现了示例代码的 bug,欢迎提交 issue。
-- 欢迎加入 QQ 群:**646165204**,进行技术交流和反馈~
-- 

+ 0 - 927
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.js

@@ -1,927 +0,0 @@
-import TUICallEngine, { EVENT, MEDIA_TYPE, AUDIO_PLAYBACK_DEVICE, STATUS } from 'tuicall-engine-wx';
-import { BellContext } from './serve/bellContext';
-import { throttle, isTabBarPage, tabBarConfig } from './utils/commom';
-import { THROTTLE_TIME } from './utils/constants';
-// 组件旨在跨终端维护一个通话状态管理机,以事件发布机制驱动上层进行管理,并通过API调用进行状态变更。
-// 组件设计思路将UI和状态管理分离。您可以通过修改`component`文件夹下的文件,适配您的业务场景,
-// 在UI展示上,您可以通过属性的方式,将上层的用户头像,名称等数据传入组件内部,`static`下的icon和默认头像图片,
-// 只是为了展示基础的效果,您需要根据业务场景进行修改。
-
-export const PREFIX = 'TUICallKit';
-const version = '1.4.4';
-let INVITER_BELL_FILEPATH = 'TUICallKit/TUICallKit/static/phone_dialing.mp3';
-let INVITEE_BELL_FILEPATH = 'TUICallKit/TUICallKit/static/phone_ringing.mp3';
-// 记录组件是否初始化完成
-let tuiCallInitReady = false;
-// 是否需要隐藏 tabBar 页面
-let shouldHideTabBar = false;
-Component({
-  properties: {
-    config: {
-      type: Object,
-      value: {
-        sdkAppID: 0,
-        userID: '',
-        userSig: '',
-        type: 1,
-        tim: null,
-      },
-    },
-    backgroundMute: {
-      type: Boolean,
-      value: false,
-    },
-  },
-  data: {
-    callStatus: STATUS.IDLE,   // idle、calling、connection
-    isSponsor: false,          // 呼叫者身份 true为呼叫者 false为被叫者
-    pusher: {},                // TRTC 本地流
-    playerList: [],            // TRTC 远端流
-    playerProcess: {},         // 经过处理的的远端流(多人通话)
-    isGroup: false,            // 是否为多人通话
-    remoteUsers: [],           // 未排序的通话列表
-    allUsers: [],              // 排序后的通话列表
-    sponsor: '',               // 主叫方
-    screen: 'pusher',          // 视屏通话中,显示大屏幕的流(只限1v1聊天
-    soundMode: AUDIO_PLAYBACK_DEVICE.SPEAKER,  // 声音模式 听筒/扬声器
-    showToatTime: 0,           // 弹窗时长
-    ownUserId: '',
-    callingBell: null,
-    bellFilePath: '',          // 被叫方铃声地址
-  },
-  methods: {
-    initialUI() {
-      // 收起键盘
-      wx.hideKeyboard();
-      // 隐藏 tabBar
-      if (shouldHideTabBar) {
-        wx.hideTabBar();
-      }
-    },
-    // 新的邀请回调事件
-    async handleNewInvitationReceived(event) {
-      this.initialUI();
-      this.checkRunPlatform();
-      this.data.config.type = event.data.inviteData.callType;
-      this.data.callingBell.setBellSrc(this.data.bellFilePath || INVITEE_BELL_FILEPATH);
-      this.data.callingBell.play();
-      // 判断是否为多人通话
-      if (event.data.isFromGroup) {
-        this.setData({
-          isGroup: true,
-          sponsor: event.data.sponsor,
-        });
-        // 将主叫方和被叫列表合并在一起 组成全部通话人数
-        const newList = [...event.data.inviteeList, event.data.sponsor];
-        // 获取用户信息
-        await this.getUserProfile(newList);
-      } else {
-        await this.getUserProfile([event.data.sponsor]);
-      }
-      this.setData({
-        config: this.data.config,
-        callStatus: STATUS.CALLING,
-        isSponsor: false,
-      });
-    },
-    // 用户接听
-    handleUserAccept(event) {
-      // 主叫方则唤起通话页面
-      if (this.isSponsor()) {
-        this.data.callingBell && this.data.callingBell.stop();
-        this.setData({
-          callStatus: STATUS.CONNECTED,
-        });
-      }
-    },
-    // 远端用户进入通话
-    handleUserEnter(res) {
-      const newList = this.data.allUsers;
-      // 多人通话
-      if (this.data.isGroup) {
-        // 改变远端用户信息中的isEnter属性
-        for (let i = 0;i < newList.length;i++) {
-          if (newList[i].userID === res.data.userID) {
-            newList[i].isEnter = true;
-          }
-        }
-      }
-      this.setData({
-        playerList: res.playerList,
-        allUsers: newList,
-      });
-    },
-    // 远端用户离开通话
-    handleUserLeave(res) {
-      // 多人通话
-      if (this.data.isGroup) {
-        wx.showToast({
-          title: `${this.getUserNickName(res.data.userID)}离开通话`,
-        });
-        this.deleteUsers(this.data.allUsers, res.data.userID);
-      }
-      this.setData({
-        playerList: res.data.playerList,
-      });
-    },
-    // 用户数据更新
-    handleUserUpdate(res) {
-      this.handleNetStatus(res.data);
-      const newplayer = {};
-      const newres = res.data.playerList;
-      // 多人通话
-      if (this.data.isGroup) {
-        // 处理远端流
-        for (let i = 0;i < newres.length;i++) {
-          const  { userID } = newres[i];
-          newplayer[userID] = newres[i];
-        }
-      };
-      this.setData({
-        pusher: res.data.pusher,
-        playerList: res.data.playerList,
-        playerProcess: newplayer,
-      });
-    },
-    // 判断网络状态
-    handleNetStatus(data) {
-      if (data.pusher.netQualityLevel > 4) {
-        wx.showToast({
-          icon: 'none',
-          title: '您当前网络不佳',
-        });
-      }
-      data.playerList.map((item) => {
-        if (item.netStatus.netQualityLevel > 4) {
-          const name = data.playerList.length > 1 ? item.nick : '对方';
-          wx.showToast({
-            icon: 'none',
-            title: `${name}当前网络不佳`,
-          });
-        }
-        return item;
-      });
-    },
-    // 用户拒绝
-    handleInviteeReject(event) {
-      if (this.data.isGroup) {
-        this.deleteUsers(this.data.allUsers, event.data.invitee);
-      } else {
-        this.data.callingBell && this.data.callingBell.stop();
-      }
-      wx.showToast({
-        title: `${this.getUserNickName(event.data.invitee)}已拒绝`,
-      });
-    },
-    // 用户不在线
-    handleNoResponse(event) {
-      if (this.data.isGroup) {
-        this.deleteUsers(this.data.allUsers, event.data.timeoutUserList);
-      } else {
-        this.data.callingBell && this.data.callingBell.stop();
-      }
-      wx.showToast({
-        icon: 'none',
-        title: `${event.data.timeoutUserList}无应答`,
-      });
-    },
-    // 获取用户昵称
-    getUserNickName(userId) {
-      const { remoteUsers } = this.data;
-      const userObj = remoteUsers.find(item => item.userID === userId);
-      return userObj.nick ? userObj.nick : userObj.userID;
-    },
-    // 用户忙线
-    handleLineBusy(event) {
-      if (this.data.isGroup) {
-        this.deleteUsers(this.data.allUsers, event.data.invitee);
-      } else {
-        this.data.callingBell && this.data.callingBell.stop();
-      }
-      this.showToast(this.getUserNickName(event.data.invitee));
-    },
-    showToast(event) {
-      this.setData({
-        showToatTime: this.data.showToatTime + THROTTLE_TIME,
-      });
-      setTimeout(() => {
-        wx.showToast({
-          title: `${event}忙线中`,
-        });
-      }, this.data.showToatTime);
-    },
-    // 用户取消
-    handleCallingCancel(event) {
-      this.data.callingBell && this.data.callingBell.stop();
-      if (event.data.invitee !== this.data.config.userID) {
-        wx.showToast({
-          title: `${this.getUserNickName(event.data.invitee)}取消通话`,
-        });
-      }
-      this.reset();
-    },
-    // 通话超时未应答
-    handleCallingTimeout(event) {
-      if (this.data.isGroup) {
-        // 若是自身未应答 则不弹窗
-        if (this.data.config.userID === event.data.timeoutUserList[0]) {
-          this.reset();
-          return;
-        }
-        const newList = this.deleteUsers(this.data.allUsers, event.data.timeoutUserList);
-        this.setData({
-          allUsers: newList,
-        });
-      } else {
-        this.data.callingBell && this.data.callingBell.stop();
-      }
-      if (this.data.playerList.length === 0) {
-        this.reset();
-      }
-      wx.showToast({
-        title: `${event.data.timeoutUserList[0]}超时无应答`,
-      });
-    },
-    handleCallingUser(userIDList) {
-      const remoteUsers = [...this.data.remoteUsers];
-      const userProfile = remoteUsers.filter(item => userIDList.some(userItem => `${userItem}` === item.userID));
-      this.setData({
-        remoteUsers: remoteUsers.filter(item => userIDList.some(userItem => userItem !== item.userID)),
-      });
-      let nick = '';
-      for (let i = 0; i < userProfile.length; i++) {
-        nick += `${userProfile[i].nick}、`;
-      }
-      return nick.slice(0, -1);
-    },
-    // 通话结束
-    handleCallingEnd(event) {
-      wx.showToast({
-        title: '通话结束',
-        duration: 800,
-      });
-      this.reset();
-    },
-    // SDK Ready 回调
-    handleSDKReady() {
-      // 呼叫需在sdk ready之后
-    },
-    // 被踢下线
-    handleKickedOut() {
-      wx.showToast({
-        title: '您已被踢下线',
-      });
-    },
-    // 切换通话模式
-    handleCallMode(event) {
-      this.data.config.type = event.data.type;
-      this.setSoundMode(AUDIO_PLAYBACK_DEVICE.EAR);
-      this.setData({
-        config: this.data.config,
-      });
-    },
-    handleError(event) {
-      const { code, message } = event.data || {};
-      console.warn(`${PREFIX} errorCode: ${code}, errorMessage: ${message}`);
-    },
-    // 删除用户列表操作
-    deleteUsers(usersList, userID) {
-      // 若userID不是数组,则将其转换为数组
-      if (!Array.isArray(userID)) {
-        userID = [userID];
-      }
-      const list = usersList.filter(item => !userID.includes(item.userID));
-      this.setData({
-        allUsers: list,
-      });
-    },
-    // 增加用户列表操作
-    addUsers(usersList, userID) {
-      // 若userID不是数组,则将其转换为数组
-      if (!Array.isArray(userID)) {
-        userID = [userID];
-      }
-      const newList = [...usersList, ...userID];
-      return newList;
-    },
-    // 增加 tsignaling 事件监听
-    _addTSignalingEvent() {
-      wx.$TUICallEngine.on(EVENT.ERROR, this.handleError, this);
-      // 被邀请通话
-      wx.$TUICallEngine.on(EVENT.INVITED, this.handleNewInvitationReceived, this);
-      // 用户接听
-      wx.$TUICallEngine.on(EVENT.USER_ACCEPT, this.handleUserAccept, this);
-      // 用户进入通话
-      wx.$TUICallEngine.on(EVENT.USER_ENTER, this.handleUserEnter, this);
-      // 用户离开通话
-      wx.$TUICallEngine.on(EVENT.USER_LEAVE, this.handleUserLeave, this);
-      // 用户更新数据
-      wx.$TUICallEngine.on(EVENT.USER_UPDATE, this.handleUserUpdate, this);
-      // 用户拒绝通话
-      wx.$TUICallEngine.on(EVENT.REJECT, this.handleInviteeReject, this);
-      // 用户无响应
-      wx.$TUICallEngine.on(EVENT.NO_RESP, this.handleNoResponse, this);
-      // 用户忙线
-      wx.$TUICallEngine.on(EVENT.LINE_BUSY, this.handleLineBusy, this);
-      // 通话被取消
-      wx.$TUICallEngine.on(EVENT.CALLING_CANCEL, this.handleCallingCancel, this);
-      // 通话超时未应答
-      wx.$TUICallEngine.on(EVENT.CALLING_TIMEOUT, this.handleCallingTimeout, this);
-      // 通话结束
-      wx.$TUICallEngine.on(EVENT.CALL_END, this.handleCallingEnd, this);
-      // SDK Ready 回调
-      wx.$TUICallEngine.on(EVENT.SDK_READY, this.handleSDKReady, this);
-      // 被踢下线
-      wx.$TUICallEngine.on(EVENT.KICKED_OUT, this.handleKickedOut, this);
-      // 切换通话模式
-      wx.$TUICallEngine.on(EVENT.CALL_MODE, this.handleCallMode, this);
-      // 自己发送消息
-      wx.$TUICallEngine.on(EVENT.MESSAGE_SENT_BY_ME, this.messageSentByMe, this);
-    },
-    // 取消 tsignaling 事件监听
-    _removeTSignalingEvent() {
-      wx.$TUICallEngine.off(EVENT.ERROR, this.handleError);
-      // 被邀请通话
-      wx.$TUICallEngine.off(EVENT.INVITED, this.handleNewInvitationReceived);
-      // 用户接听
-      wx.$TUICallEngine.off(EVENT.USER_ACCEPT, this.handleUserAccept);
-      // 用户进入通话
-      wx.$TUICallEngine.off(EVENT.USER_ENTER, this.handleUserEnter);
-      // 用户离开通话
-      wx.$TUICallEngine.off(EVENT.USER_LEAVE, this.handleUserLeave);
-      // 用户更新数据
-      wx.$TUICallEngine.off(EVENT.USER_UPDATE, this.handleUserUpdate);
-      // 用户拒绝通话
-      wx.$TUICallEngine.off(EVENT.REJECT, this.handleInviteeReject);
-      // 用户无响应
-      wx.$TUICallEngine.off(EVENT.NO_RESP, this.handleNoResponse);
-      // 用户忙线
-      wx.$TUICallEngine.off(EVENT.LINE_BUSY, this.handleLineBusy);
-      // 通话被取消
-      wx.$TUICallEngine.off(EVENT.CALLING_CANCEL, this.handleCallingCancel);
-      // 通话超时未应答
-      wx.$TUICallEngine.off(EVENT.CALLING_TIMEOUT, this.handleCallingTimeout);
-      // 通话结束
-      wx.$TUICallEngine.off(EVENT.CALL_END, this.handleCallingEnd);
-      // SDK Ready 回调
-      wx.$TUICallEngine.off(EVENT.SDK_READY, this.handleSDKReady);
-      // 被踢下线
-      wx.$TUICallEngine.off(EVENT.KICKED_OUT, this.handleKickedOut);
-      // 切换通话模式
-      wx.$TUICallEngine.off(EVENT.CALL_MODE, this.handleCallMode);
-      // 自己发送消息
-      wx.$TUICallEngine.off(EVENT.MESSAGE_SENT_BY_ME, this.messageSentByMe);
-    },
-    /**
-     * C2C邀请通话,被邀请方会收到的回调
-     * 如果当前处于通话中,可以调用该函数以邀请第三方进入通话
-     * @param {Object} params 呼叫参数
-     * @param {String} params.userID 被邀请方
-     * @param {Number} params.type 0-未知,1-语音通话,2-视频通话
-     * @param {Number} params.roomID 数字房间号, 范围 1~2147483647
-     * @param {String=} params.userData 扩展字段: 用于在邀请信令中增加扩展信息
-     */
-    call: throttle(async function (params) {
-      this.initialUI();
-      if (this.data.callStatus !== STATUS.IDLE) {
-        return;
-      }
-      this.checkRunPlatform();
-      this.data.config.type = params.type;
-      // 检查设备权限
-      const deviceMap = {
-        microphone: true,
-        camera: params.type === MEDIA_TYPE.VIDEO,
-      };
-      const hasDevicePermission = await wx.$TUICallEngine.deviceCheck(deviceMap);
-      const callStatus = hasDevicePermission ? STATUS.CALLING : STATUS.IDLE;
-      this.setData({
-        callStatus,
-        isSponsor: true,
-        config: this.data.config,
-      });
-      try {
-        await this.getUserProfile([params.userID]);
-      } catch (error) {
-        console.warn(error);
-      }
-      wx.$TUICallEngine.call({ userID: params.userID, type: params.type, roomID: params.roomID, userData: params.userData }).then(async (res) => {
-        if (res) {
-          this.setData({
-            callStatus: STATUS.CALLING,
-            pusher: res.pusher,
-          });
-          this.data.callingBell.setBellSrc(INVITER_BELL_FILEPATH);
-          this.data.callingBell.play();
-          this.setSoundMode(this.data.config.type === MEDIA_TYPE.AUDIO ? AUDIO_PLAYBACK_DEVICE.EAR : AUDIO_PLAYBACK_DEVICE.SPEAKER);
-        }
-      })
-        .catch((error) => {
-          if (error.code === -1002) {
-            wx.showModal({
-              icon: 'none',
-              title: 'error',
-              content: error.message,
-              showCancel: false,
-            });
-          }
-          this.reset();
-          throw new Error(error);
-        });
-    }, THROTTLE_TIME),
-    /**
-     * IM群组邀请通话,被邀请方会收到的回调
-     * 如果当前处于通话中,可以继续调用该函数继续邀请他人进入通话,同时正在通话的用户会收到的回调
-     *
-     * @param {Object} params 呼叫参数
-     * @param {Array<String>} params.userIDList 邀请列表
-     * @param {Number} params.type 1-语音通话,2-视频通话
-     * @param {String} params.groupID IM群组ID
-     * @param {Number} params.roomID 数字房间号, 范围 1~2147483647
-     * @param {String=} params.userData 扩展字段: 用于在邀请信令中增加扩展信息
-     */
-    groupCall: throttle(async function (params) {
-      // 判断是否存在groupID
-      if (!params.groupID) {
-        wx.showToast({
-          title: '群ID为空',
-        });
-        return;
-      }
-      this.initialUI();
-      if (this.data.callStatus !== STATUS.IDLE) {
-        return;
-      }
-      this.checkRunPlatform();
-      this.data.config.type = params.type;
-      // 检查设备权限
-      const deviceMap = {
-        microphone: true,
-        camera: params.type === MEDIA_TYPE.VIDEO,
-      };
-      const hasDevicePermission = await wx.$TUICallEngine.deviceCheck(deviceMap);
-      const callStatus = hasDevicePermission ? STATUS.CALLING : STATUS.IDLE;
-      this.setData({
-        callStatus,
-        isSponsor: true,
-        isGroup: true,
-        sponsor: this.data.config.userID,
-        config: this.data.config,
-      });
-      // 将自身的userID插入到邀请列表中,组成完整的用户信息
-      const list = JSON.parse(JSON.stringify(params.userIDList));
-      list.unshift(this.data.config.userID);
-      // 获取用户信息
-      try {
-        await this.getUserProfile(list);
-      } catch (error) {
-        console.warn(error);
-      }
-      wx.$TUICallEngine.groupCall({
-        userIDList: params.userIDList,
-        type: params.type,
-        groupID: params.groupID,
-        roomID: params.roomID,
-        userData: params.userData,
-      }).then(async (res) => {
-        if (res) {
-          this.data.config.type = params.type;
-          this.setData({
-            pusher: res.pusher,
-            callStatus: STATUS.CALLING,
-          });
-          this.data.callingBell.setBellSrc(INVITER_BELL_FILEPATH);
-          this.data.callingBell.play();
-        }
-      })
-        .catch((error) => {
-          if (error.code === -1002) {
-            wx.showModal({
-              icon: 'none',
-              title: 'error',
-              content: error.message,
-              showCancel: false,
-            });
-          }
-          this.reset();
-          throw new Error(error);
-        });
-    }, THROTTLE_TIME),
-    /**
-     * 当您作为被邀请方收到 {@link TRTCCallingDelegate#onInvited } 的回调时,可以调用该函数接听来电
-     */
-    accept: throttle(async function () {
-      wx.$TUICallEngine.accept().then((res) => {
-        if (res) {
-          this.data.callingBell && this.data.callingBell.stop();
-          this.setData({
-            pusher: res.pusher,
-            callStatus: STATUS.CONNECTED,
-          });
-          // 多人通话需要对自身位置进行修正,将其放到首位
-          if (this.data.isGroup) {
-            const newList = this.data.allUsers;
-            for (let i = 0;i < newList.length;i++) {
-              if (newList[i].userID === this.data.config.userID) {
-                newList[i].isEnter = true;
-                [newList[i], newList[0]] = [newList[0], newList[i]];
-              }
-            };
-            this.setData({
-              allUsers: newList,
-            });
-          }
-        }
-      })
-        .catch((error) => {
-          console.error(error);
-          this.reset();
-        });
-    }, THROTTLE_TIME),
-    /**
-     * 当您作为被邀请方收到的回调时,可以调用该函数拒绝来电
-     */
-    reject: throttle(async function () {
-      wx.$TUICallEngine.reject().then((res) => {
-        this.data.callingBell && this.data.callingBell.stop();
-        this.reset();
-      })
-        .catch((error) => {
-          console.error(error);
-          this.reset();
-        });
-    }, THROTTLE_TIME),
-    messageSentByMe(event) {
-      const message = event.data.data;
-      this.triggerEvent('sendMessage', {
-        message,
-      });
-    },
-    // xml层,是否开启扬声器
-    setSoundMode(type) {
-      this.setData({
-        soundMode: wx.$TUICallEngine.selectAudioPlaybackDevice(type),
-      });
-    },
-    // xml层,挂断
-    hangup: throttle(async function () {
-      try {
-        await wx.$TUICallEngine.hangup();
-        this.reset();
-      } catch (error) {
-        console.error(error);
-        this.reset();
-      }
-    }, THROTTLE_TIME),
-    //  切换大小屏 (仅支持1v1聊天)
-    toggleViewSize(event) {
-      this.setData({
-        // FIXME _toggleViewSize 不应该为TUICallEngine的方法 后续修改
-        screen: wx.$TUICallEngine._toggleViewSize(event),
-      });
-    },
-    // 数据重置
-    reset() {
-      if (shouldHideTabBar) {
-        wx.showTabBar();
-      }
-      this.setData({
-        callStatus: STATUS.IDLE,
-        isSponsor: false,
-        isGroup: false,
-        soundMode: AUDIO_PLAYBACK_DEVICE.SPEAKER,
-        pusher: {}, // TRTC 本地流
-        playerList: [], // TRTC 远端流
-        showToatTime: 0,
-      });
-    },
-    // 呼叫中的事件处理
-    async handleCallingEvent(data) {
-      const { name, event } = data.detail;
-      switch (name) {
-        case 'accept':
-          this.setSoundMode(this.data.config.type === MEDIA_TYPE.AUDIO ? AUDIO_PLAYBACK_DEVICE.EAR : AUDIO_PLAYBACK_DEVICE.SPEAKER);
-          this.accept();
-          break;
-        case 'hangup':
-          await this.hangup();
-          break;
-        case 'reject':
-          await this.reject();
-          break;
-        case 'toggleSwitchCamera':
-          wx.$TUICallEngine.switchCamera();
-          break;
-        case 'switchAudioCall':
-          wx.$TUICallEngine.switchCallMediaType(MEDIA_TYPE.AUDIO).then((res) => {
-            this.data.config.type = MEDIA_TYPE.AUDIO;
-            this.setSoundMode(AUDIO_PLAYBACK_DEVICE.EAR);
-            this.setData({
-              config: this.data.config,
-            });
-          });
-          break;
-        case 'pusherErrorHandler':
-          this.pusherErrorHandler(event.errMsg);
-          break;
-        default:
-          break;
-      }
-    },
-    // 通话中的事件处理
-    async handleConnectedEvent(data) {
-      const { name, event } = data.detail;
-      switch (name) {
-        case 'toggleViewSize':
-          this.toggleViewSize(event);
-          break;
-        case 'pusherNetStatus':
-          wx.$TUICallEngine._pusherNetStatus(event);
-          break;
-        case 'playNetStatus':
-          wx.$TUICallEngine._playNetStatus(event);
-          break;
-        case 'pusherStateChangeHandler':
-          wx.$TUICallEngine._pusherStateChangeHandler(event);
-          break;
-        case 'pusherAudioVolumeNotify':
-          wx.$TUICallEngine._pusherAudioVolumeNotify(event);
-          break;
-        case 'playerStateChange':
-          wx.$TUICallEngine._playerStateChange(event);
-          break;
-        case 'playerAudioVolumeNotify':
-          wx.$TUICallEngine._playerAudioVolumeNotify(event);
-          break;
-        case 'pusherAudioHandler':
-          wx.$TUICallEngine._pusherAudioHandler(event);
-          break;
-        case 'hangup':
-          await this.hangup();
-          break;
-        case 'toggleSoundMode':
-          this.setSoundMode(this.data.soundMode === AUDIO_PLAYBACK_DEVICE.EAR ? AUDIO_PLAYBACK_DEVICE.SPEAKER : AUDIO_PLAYBACK_DEVICE.EAR);
-          break;
-        case 'pusherVideoHandler':
-          wx.$TUICallEngine._pusherVideoHandler(event);
-          break;
-        case 'toggleSwitchCamera':
-          wx.$TUICallEngine.switchCamera(event);
-          break;
-        case 'switchAudioCall':
-          wx.$TUICallEngine.switchCallMediaType(MEDIA_TYPE.AUDIO).then((res) => {
-            this.data.config.type = MEDIA_TYPE.AUDIO;
-            this.setData({
-              config: this.data.config,
-            });
-            this.setSoundMode(AUDIO_PLAYBACK_DEVICE.EAR);
-          });
-          break;
-        case 'pusherErrorHandler':
-          this.pusherErrorHandler(event.errMsg);
-          break;
-        default:
-          break;
-      }
-    },
-    // 处理 pusher 中的异常问题
-    pusherErrorHandler(code) {
-      switch (code) {
-        case 'fail:access denied':
-          wx.showModal({
-            icon: 'none',
-            title: '权限提示',
-            content: '当前小程序 appid 不具备 <live-pusher> 和 <live-player> 的使用权限,您将无法正常使用实时通话能力,请使用企业小程序账号申请权限后再进行开发体验',
-            showCancel: false,
-          });
-          break;
-
-        default:
-          break;
-      }
-    },
-    // 设置用户的头像、昵称
-    setSelfInfo(nickName, avatar) {
-      return wx.$TUICallEngine.setSelfInfo(nickName, avatar);
-    },
-    // 获取用户资料
-    async getUserProfile(userList) {
-      const imResponse = await this.getTim().getUserProfile({ userIDList: userList });
-      // 修正用户资料
-      this.modifyUser(imResponse.data);
-    },
-    // 修正用户资料
-    modifyUser(userIDList) {
-      const { sponsor } = this.data;
-      if (this.data.isGroup) {
-        // 多人通话需要将呼叫者放到第一位 isEnter的作用是区分用户是否进入房间
-        for (let i = 0;i < userIDList.length;i++) {
-          // 主叫方的标志位设置成true
-          if (userIDList[i].userID === sponsor) {
-            userIDList[i].isEnter = true;
-            // 对主叫方位置进行修正 将其放到首位
-            [userIDList[i], userIDList[0]] = [userIDList[0], userIDList[i]];
-          } else {
-          // 其他用户默认未进入房间 设置为false
-            userIDList[i].isEnter = false;
-          }
-        }
-        this.setData({
-          allUsers: userIDList,
-        });
-      }
-      this.setData({
-        remoteUsers: userIDList,
-      });
-    },
-    // 获取 tim 实例
-    getTim() {
-      return wx.$TUICallEngine.getTim();
-    },
-
-    // 设置日志级别,低于 level 的日志将不会输出
-    setLogLevel(leave) {
-      wx.$TUICallEngine.setLogLevel(leave);
-    },
-
-    // 初始化TUICallKit
-    async init(params) {
-      if (tuiCallInitReady) return;
-      tuiCallInitReady = true;
-      // 关于 tabBar 页面的特化逻辑
-      this.handleTabBarLogic();
-      // 兼容从config和init中传值
-      const { sdkAppID, tim, userID, userSig, SDKAppID } = { ...this.data.config, ...params };
-      this.setData({
-        ownUserId: userID,
-        config: {
-          ...this.data.config,
-          sdkAppID: sdkAppID || SDKAppID,
-          userID,
-          userSig,
-        },
-      });
-      // 取消全局监听
-      if (wx.$globalCallSign) {
-        wx.$CallManagerInstance.removeEngineInvite();
-      }
-      this.setUniBellFilePath();
-      if (!this.data.callingBell) {  // 创建铃声实例
-        const bellContext = new BellContext();
-        this.setData({
-          callingBell: bellContext,
-        });
-      }
-      if (!wx.$TUICallEngine) {
-        wx.$TUICallEngine = TUICallEngine.createInstance({
-          tim,
-          sdkAppID: sdkAppID || SDKAppID,
-        });
-        /*
-        _addTSignalingEvent 需要在 init 之前,回调才能正常触发
-        tap:https://tapd.woa.com/20396022/prong/stories/view/1020396022885781069
-        */
-        this._addTSignalingEvent();
-        try {
-          await wx.$TUICallEngine.init({
-            userID,
-            userSig,
-          });
-        } catch (error) {
-          tuiCallInitReady = false;
-          throw new Error(error);
-        }
-        // 用于全局监听进入 TUICallKit 页面中绑定上当前页面的监听。
-      } else {
-        this._addTSignalingEvent();
-      }
-      console.log(`${PREFIX} init Ready!`);
-    },
-    // 销毁 TUICallEngine
-    async destroyed() {
-      if (!wx.$TUICallEngine || !tuiCallInitReady) return;
-      tuiCallInitReady = false;
-      this._removeTSignalingEvent();
-      // 全局监听模式下,离开页面需要重新绑定全局监听,但不卸载 TUICallEngine
-      if (wx.$globalCallSign) {
-        // 处理异常退出
-        if (this.getCallStatus() !== STATUS.IDLE) {
-          await this.handleExceptionExit();
-        }
-        wx.$CallManagerInstance.addEngineInvite();
-      } else {
-        // 非全局监听模式下,离开页面需要卸载 TUICallEngine
-        wx.$TUICallEngine.destroyInstance();
-        wx.$TUICallEngine = null;
-      }
-      if (this.data.callingBell) {
-        this.data.callingBell.destroyInstance();
-        this.setData({
-          callingBell: null,
-        });
-      }
-      this.reset();
-      console.log(`${PREFIX} destroyed OK!`);
-    },
-
-    /*
-      以下两种情况需要全部符合,则需要隐藏 tabBar
-      1.用户当前处于 tabBar 页面, isTabBar 为 true
-      2.用户没有使用了自定义 tabBar, isCustomTabBar 为 fales
-      */
-    handleTabBarLogic() {
-      const isTabBar = isTabBarPage();
-      const isCustomTabBar = tabBarConfig().custom || false;
-      shouldHideTabBar = isTabBar && !isCustomTabBar;
-    },
-
-    // 检测运行时环境
-    checkRunPlatform() {
-      const systemInfo = wx.getSystemInfoSync();
-      if (systemInfo.platform === 'devtools') {
-      // 当前运行在微信开发者工具里
-        wx.showModal({
-          icon: 'none',
-          title: '运行环境提醒',
-          content: '微信开发者工具不支持原生推拉流组件(即 <live-pusher> 和 <live-player> 标签),请使用真机调试或者扫码预览。',
-          showCancel: false,
-        });
-      }
-    },
-    // 运行在 uniapp 小程序需要修改铃声地址
-    setUniBellFilePath() {
-      // 防止用户退出再进入,在地址前重复拼接
-      if (INVITER_BELL_FILEPATH.indexOf('wxcomponents') !== -1) {
-        return;
-      }
-      // comType 用于 Vue2 的判断,wxcomponents 用于 Vue3 的判断
-      if (this.dataset.comType === 'wx' || this.is.indexOf('wxcomponents') !== -1) {
-        INVITER_BELL_FILEPATH = `wxcomponents/${INVITER_BELL_FILEPATH}`;
-        INVITEE_BELL_FILEPATH = `wxcomponents/${INVITEE_BELL_FILEPATH}`;
-      }
-    },
-    // 自定义铃声
-    setCallingBell(filePath) {
-      // 如需恢复默认铃声,filePath 传空即可
-      this.setData({
-        bellFilePath: filePath,
-      });
-    },
-    // 处理用户异常退出的情况,处理了右滑退出,以及返回退出的情况。
-    async handleExceptionExit() {
-      // 在呼叫状态下,被叫调用 reject,主叫调用 hangup
-      if (this.getCallStatus() === STATUS.CALLING) {
-        if (this.isSponsor()) {
-          await this.hangup();
-        } else {
-          await this.reject();
-        }
-      }
-      // 在通话状态下,统一调用 hangup 接口
-      if (this.getCallStatus() === STATUS.CONNECTED) {
-        await this.hangup();
-      }
-    },
-
-    getCallStatus() {
-      return this.data.callStatus;
-    },
-
-    isSponsor() {
-      return this.data.isSponsor;
-    },
-  },
-  /**
-   * 生命周期方法
-   */
-  lifetimes: {
-    created() {
-      this.reset();
-    },
-    attached() {
-
-    },
-    ready() {
-      console.log(`${PREFIX} SDK Version: ${version}`);
-    },
-    async detached() {
-      await this.destroyed();
-    },
-    error() {
-    },
-  },
-  pageLifetimes: {
-    async show() {
-      if (this.data.config.sdkAppID) {
-        await this.init(this.data.config);
-      }
-    },
-    async hide() {
-      if (this.getCallStatus() === STATUS.IDLE) {
-        await this.destroyed();
-      }
-    },
-    resize() {
-    },
-  },
-});

+ 0 - 11
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.json

@@ -1,11 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {
-    "TUI-Calling": "./component/calling/calling",
-    "TUI-Connected": "./component/connected/connected",
-    "TUI-groupCalling": "./component/groupCalling/groupCalling",
-    "TUI-groupConnected": "./component/groupConnected/groupConnected"
-  },
-  "navigationStyle": "custom",
-  "disableScroll": true
-}

+ 0 - 52
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.wxml

@@ -1,52 +0,0 @@
-<view class="TUICalling {{callStatus === 'idle' ? 'hidden': 'show'}}">
-  <view class="TRTCCaling-container {{isGroup && config.type === 2 ?'groupConnected':''}}">
-    <TUI-Calling
-      wx:if="{{callStatus === 'calling' && !isGroup}}"
-      isSponsor="{{isSponsor}}"
-      pusher="{{pusher}}"
-      isGroup="{{isGroup}}"
-      callType="{{config.type}}"
-      remoteUsers="{{remoteUsers}}"
-      bind:callingEvent="handleCallingEvent"
-    ></TUI-Calling>
-
-    <TUI-groupCalling
-      wx:if="{{callStatus === 'calling' && isGroup}}"
-      isSponsor="{{isSponsor}}"
-      pusher="{{pusher}}"
-      isGroup="{{isGroup}}"
-      callType="{{config.type}}"
-      allUsers="{{allUsers}}"
-      ownUserId="{{ownUserId}}"
-      bind:callingEvent="handleCallingEvent"
-    ></TUI-groupCalling>
-
-
-    <TUI-Connected
-      wx:if="{{callStatus === 'connected' && !isGroup}}"
-      playerList="{{playerList}}"
-      isGroup="{{isGroup}}"
-      userList="{{userList}}"
-      pusher="{{pusher}}"
-      callType="{{config.type}}"
-      soundMode="{{soundMode}}"
-      screen="{{screen}}"
-      bind:connectedEvent="handleConnectedEvent"
-    ></TUI-Connected>
-
-    <TUI-groupConnected
-      wx:if="{{callStatus === 'connected'  && isGroup}}"
-      allUsers="{{allUsers}}"
-      playerList="{{playerList}}"
-      userList="{{userList}}"
-      isGroup="{{isGroup}}"
-      pusher="{{pusher}}"
-      callType="{{config.type}}"
-      soundMode="{{soundMode}}"
-      screen="{{screen}}"
-      ownUserId="{{ownUserId}}"
-      playerProcess="{{ playerProcess}}"
-      bind:connectedEvent="handleConnectedEvent"
-    ></TUI-groupConnected>
-  </view>
-</view>

+ 0 - 25
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/TUICallKit.wxss

@@ -1,25 +0,0 @@
-.TRTCCaling-container {
-	width: 100vw;
-	height: 100vh;
-	overflow: hidden;
-	/* background-image: url(https://mc.qcloudimg.com/static/img/7da57e0050d308e2e1b1e31afbc42929/bg.png); */
-	margin: 0;
-}
-.hidden {
-	display: none;
-}
-.TUICalling {
-	position: fixed;
-	width: 100vw;
-	height: 100vh;
-	z-index: 10;
-	background: #ffffff;
-}
-.show {
-	top: 0;
-	left: 0;
-}
-
-.groupConnected{
-	background-color: #2c292923;
-}

+ 0 - 108
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.js

@@ -1,108 +0,0 @@
-// components/tui-calling/TUICalling/component/calling.js
-Component({
-  /**
-   * 组件的属性列表
-   */
-  properties: {
-    isSponsor: {
-      type: Boolean,
-      value: false,
-    },
-    pusher: {
-      type: Object,
-    },
-    callType: {
-      type: Number,
-    },
-    remoteUsers: {
-      type: Array,
-    },
-    isGroup: {
-      type: Boolean,
-    },
-  },
-  /**
-   * 组件的初始数据
-   */
-  data: {
-
-  },
-
-  /**
-   * 生命周期方法
-   */
-  lifetimes: {
-    created() {
-
-    },
-    attached() {
-    },
-    ready() {
-    },
-    detached() {
-    },
-    error() {
-    },
-  },
-
-  /**
-   * 组件的方法列表
-   */
-  methods: {
-    accept(event) {
-      const data = {
-        name: 'accept',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    hangup(event) {
-      const data = {
-        name: 'hangup',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    reject(event) {
-      const data = {
-        name: 'reject',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    handleErrorImage(e) {
-      const { id } = e.target;
-      const remoteUsers = this.data.remoteUsers.map((item) => {
-        if (item.userID === id) {
-          item.avatar = '../../static/default_avatar.png';
-        }
-        return item;
-      });
-      this.setData({
-        remoteUsers,
-      });
-    },
-    toggleSwitchCamera(event) {
-      const data = {
-        name: 'toggleSwitchCamera',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    switchAudioCall(event) {
-      const data = {
-        name: 'switchAudioCall',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    pusherErrorHandler(event) {
-      const { detail = '' } = event;
-      const data = {
-        name: 'pusherErrorHandler',
-        event: detail,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-  },
-});

+ 0 - 4
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.json

@@ -1,4 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {}
-}

+ 0 - 106
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.wxml

@@ -1,106 +0,0 @@
-<view class="invite-call transition-animation" wx:if="{{callType === 2}}">
-    <!-- wx:if="{{pusher.frontCamera}}" 为了处理下滑动画卡顿的问题 -->
-    <live-pusher class="local-video" wx:if="{{pusher.frontCamera}}" device-position="{{pusher.frontCamera}}" binderror="pusherErrorHandler"/>
-    <view class="invite-calling">
-        <view class="invite-calling-header" wx:if="{{remoteUsers.length === 1}}">
-            <!-- <view class="invite-calling-header-left">
-                <image src="../../static/swtich-camera.png" data-device="{{pusher.frontCamera}}"
-                    catch:tap="toggleSwitchCamera" />
-            </view> -->
-            <view class="invite-calling-header-right">
-                <view class="invite-calling-header-message">
-                    <label class="tips">{{remoteUsers[0].nick || remoteUsers[0].userID}}</label>
-                    <text class="tips-subtitle" wx:if="{{!isSponsor}}">邀请你视频通话</text>
-                    <text class="tips-subtitle" wx:else>等待对方接受</text>
-                </view>
-                <image class="avatar" src="{{remoteUsers[0].avatar || '../../static/default_avatar.png'}}"
-                    id="{{remoteUsers[0].userID}}" binderror="handleErrorImage" />
-            </view>
-        </view>
-        <view class="invite-calling-header invite-calling-list" wx:else>
-            <view class="invite-calling-item" wx:for="{{remoteUsers}}" wx:key="userID">
-                <image class="avatar" src="{{item.avatar || '../../static/default_avatar.png'}}" id="{{item.userID}}"
-                    binderror="handleErrorImage" />
-                <view class="invite-calling-item-message">
-                    <label class="tips">{{item.nick || item.userID}}</label>
-                    <text class="tips-subtitle" wx:if="{{!isSponsor}}">邀请你视频通话</text>
-                    <text class="tips-subtitle" wx:else>等待对方接受</text>
-                </view>
-            </view>
-        </view>
-        <view class="footer">
-            <view class="btn-operate" wx:if="{{isSponsor}}">
-                <view class="btn-operate-item call-switch" catch:tap="switchAudioCall">
-                    <view class="call-operate">
-                        <image src="../../static/trans.png" />
-                    </view>
-                    <text>切到语音通话</text>
-                </view>
-            </view>
-            <view class="btn-operate" wx:if="{{isSponsor}}">
-                <view class="btn-operate-item">
-                    <view class="btn-container">
-                        <view class="call-operate" catch:tap="hangup">
-                            <image src="../../static/hangup.png" />
-                        </view>
-                        <view class="invite-calling-header-left">
-                            <image src="../../static/switch_camera.png" data-device="{{pusher.frontCamera}}"
-                                catch:tap="toggleSwitchCamera" />
-                        </view>
-                    </view>
-                    <text>挂断</text>
-                </view>
-
-            </view>
-            <view class="btn-operate" wx:if="{{!isSponsor}}">
-                <view class="btn-operate-item">
-                    <view class="call-operate" style="background-color: red" catch:tap="reject">
-                        <image src="../../static/hangup.png" />
-                    </view>
-                    <text>挂断</text>
-                </view>
-                <view class="btn-operate-item">
-                    <view class="call-operate" catch:tap="accept">
-                        <image src="../../static/dialing.png" />
-                    </view>
-                    <text>接听</text>
-                </view>
-            </view>
-        </view>
-    </view>
-</view>
-
-
-<view class="incoming-call audio-call transition-animation" wx:if="{{callType === 1}}">
-    <view class="invite-calling-single">
-        <image class="avatar" src="{{remoteUsers[0].avatar || '../../static/default_avatar.png'}}"
-            id="{{remoteUsers[0].userID}}" binderror="handleErrorImage" />
-        <view class="tips">{{remoteUsers[0].nick || remoteUsers[0].userID}}</view>
-        <view wx:if="{{isSponsor && callType === 1}}" class="tips-subtitle">{{'等待对方接受'}}</view>
-    </view>
-   
-    <view class="footer">
-        <view wx:if="{{!isSponsor && callType === 1}}" class="btn-operate">
-            <view class="button-container">
-                <view class="call-operate" style="background-color: red" catch:tap="reject">
-                    <image src="../../static/hangup.png" />
-                </view>
-                <view style="margin-top:10px">挂断</view>
-            </view>
-            <view class="button-container">
-                <view class="call-operate" catch:tap="accept">
-                    <image src="../../static/dialing.png"/>
-                </view>
-                <view style="margin-top:10px">接听</view>
-            </view>
-        </view>
-        <view wx:if="{{isSponsor && callType === 1}}" class="btn-operate">
-            <view class="button-container">
-                <view class="call-operate" style="background-color: red" catch:tap="hangup">
-                    <image src="../../static/hangup.png" />
-                </view>
-                <view style="margin-top:10px">挂断</view>
-            </view>
-        </view>
-    </view>
-</view>

+ 0 - 258
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/calling/calling.wxss

@@ -1,258 +0,0 @@
-.footer {
-	position: absolute;
-	bottom: 5vh;
-	width: 100%;
-	display: flex;
-	flex-direction: column;
-	justify-content: center;
-	align-items: center;
-}
-.button-container {
-	display: flex;
-	flex-direction: column;
-	text-align: center;
-}
-
-.btn-operate {
-	display: flex;
-	justify-content: space-between;
-	/* flex-direction: column;
-    text-align: center; */
-
-}
-.btn-operate-item{
-	display: flex;
-	flex-direction: column;
-	align-items: center;
-	margin-bottom: 20px;
-}
-.btn-operate-item text {
-	font-size: 14px;
-	color: #f0e9e9;
-	padding: 5px;
-	letter-spacing: 0;
-	font-weight: 400;
-}
-
-.call-switch text{
-	padding: 5px;
-	color: #f0e9e9;
-	font-size: 14px;
-}
-
-.call-operate {
-	width: 8vh;
-	height: 8vh;
-	border-radius: 8vh;
-	margin: 0 15vw;
-	box-sizing: border-box;
-	display: flex;
-	justify-content: center;
-	align-items: center;
-}
-.call-switch .call-operate {
-	width: 4vh;
-	height: 3vh;
-}
-
-.call-operate image {
-	width: 100%;
-	height: 100%;
-	background: none;
-}
-
-.tips {
-	font-size: 20px;
-	color: #FFFFFF;
-	letter-spacing: 0;
-	margin: 0 auto;
-	/* text-shadow: 0 1px 2px rgba(0,0,0,0.40); */
-	font-weight: 600;
-	max-width: 150px;
-	overflow: hidden;
-	text-overflow: ellipsis;
-	white-space: nowrap;
-}
-.tips-subtitle {
-	font-family: PingFangSC-Regular;
-	font-size: 14px;
-	color: #FFFFFF;
-	letter-spacing: 0;
-	text-align: right;
-	/* text-shadow: 0 1px 2px rgba(0,0,0,0.30); */
-	font-weight: 400;
-}
-
-.invite-call {
-	/* background: #ffffff; */
-	position: absolute;
-	top: 0;
-	z-index: 100;
-	width: 100vw;
-	height: 100vh;
-	background-color: black;
-}
-
-.transition-animation {
-	transform: translateY(-100%);
-	animation: slideInDown 0.5s ease forwards;
-}
-
-@keyframes slideInDown {
-	from {
-	  transform: translateY(-100%);
-	}
-	to {
-	  transform: translateY(0);
-	}
-}
-
-.invite-call .local-video {
-	width: 100vw;
-	height: 100vh;
-}
-.invite-call .invite-calling {
-	position: absolute;
-	top: 0;
-	z-index: 101;
-	width: 100vw;
-	height: 100vh;
-}
-.invite-calling-header {
-	margin-top:107px;
-	display: flex;
-	justify-content: flex-end;
-	padding: 0 16px;
-
-}
-.btn-container {
-	display: flex;
-	align-items: center;
-	position: relative;
-}
-.invite-calling-header-left {
-	position: absolute;
-	right: 0;
-}
-.invite-calling-header-left image {
-	width: 32px;
-	height: 32px;
-}
-.invite-calling-header-right {
-	display: flex;
-	align-items: center;
-}
-.invite-calling-header-message {
-	display: flex;
-	flex-direction: column;
-	padding: 0 16px;
-}
-.invite-calling-header-right image {
-	width: 100px;
-	height: 100px;
-	border-radius: 12px;
-}
-.invite-calling .footer {
-	position: absolute;
-	bottom: 5vh;
-	width: 100%;
-}
-.invite-calling .btn-operate{
-	display: flex;
-	justify-content: center;
-	align-items: center;
-}
-
-
-.hidden {
-	display: none;
-}
-
-.trtc-calling {
-	width: 100vw;
-	height: 100vh;
-	overflow: hidden;
-	margin: 0;
-	z-index: 99;
-}
-
-.audio-call {
-	width: 100vw;
-	height: 100vh;
-	position: absolute;
-	top: 0;
-	z-index: 100;
-	background: #FFFFFF;
-}
-.audio-call > .btn-operate{
-	display: flex;
-	justify-content: center;
-}
-
-.audio-call > image {
-	width: 40vw;
-	height: 40vw;
-	display: block;
-	margin: 20vw 30vw;
-	margin-top: 40vw;
-}
-
-.invite-calling-single > image {
-	width: 120px;
-	height: 120px;
-	border-radius: 12px;
-	display: block;
-	margin: 140px auto 15px;
-	/* margin: 20vw 30vw; */
-}
-
-.invite-calling-single .tips {
-	width: 100%;
-	height: 40px;
-	line-height: 40px;
-	text-align: center;
-	font-size: 20px;
-	color: #333333;
-	letter-spacing: 0;
-	font-weight: 500;
-}
-.invite-calling-single .tips-subtitle {
-	height: 20px;
-	font-family: PingFangSC-Regular;
-	font-size: 14px;
-	color: #97989C;
-	letter-spacing: 0;
-	font-weight: 400;
-	text-align: center;
-}
-
-.invite-calling-list {
-	justify-content: flex-start;
-}
-
-.invite-calling-item {
-	position: relative;
-	margin: 0 12px;
-}
-.invite-calling-item image {
-	width: 100px;
-	height: 100px;
-	border-radius: 12px;
-}
-.invite-calling-item-message {
-	position: absolute;
-	background: rgba(0, 0, 0, 0.5);
-	width: 100px;
-	height: 100px;
-	top: 0;
-	left: 0;
-	z-index: 2;
-	display: flex;
-	flex-direction: column;
-	align-items: center;
-	justify-content: center;
-}
-
-.avatar {
-	background: #dddddd;
-}

+ 0 - 155
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.js

@@ -1,155 +0,0 @@
-Component({
-  /**
-   * 组件的属性列表
-   */
-  properties: {
-    playerList: {
-      type: Array,
-    },
-    pusher: {
-      type: Object,
-    },
-    callType: {
-      type: Number,
-    },
-    soundMode: {
-      type: String,
-    },
-    screen: {
-      type: String,
-    },
-    userList: {
-      type: Object,
-    },
-  },
-
-  /**
-   * 组件的初始数据
-   */
-  data: {
-
-  },
-
-  /**
-   * 组件的方法列表
-   */
-  methods: {
-    toggleViewSize(event) {
-      const data = {
-        name: 'toggleViewSize',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    pusherNetStatus(event) {
-      const data = {
-        name: 'pusherNetStatus',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    playNetStatus(event) {
-      const data = {
-        name: 'playNetStatus',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    pusherStateChangeHandler(event) {
-      const data = {
-        name: 'pusherStateChangeHandler',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    pusherAudioVolumeNotify(event) {
-      const data = {
-        name: 'pusherAudioVolumeNotify',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    pusherErrorHandler(event) {
-      const { detail = '' } = event;
-      const data = {
-        name: 'pusherErrorHandler',
-        event: detail,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    playerStateChange(event) {
-      const data = {
-        name: 'playerStateChange',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    playerAudioVolumeNotify(event) {
-      const data = {
-        name: 'playerAudioVolumeNotify',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    pusherAudioHandler(event) {
-      const data = {
-        name: 'pusherAudioHandler',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    hangup(event) {
-      const data = {
-        name: 'hangup',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    toggleSoundMode(event) {
-      const data = {
-        name: 'toggleSoundMode',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    pusherVideoHandler(event) {
-      const data = {
-        name: 'pusherVideoHandler',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    toggleSwitchCamera(event) {
-      const data = {
-        name: 'toggleSwitchCamera',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    switchAudioCall(event) {
-      const data = {
-        name: 'switchAudioCall',
-        event,
-      };
-      this.triggerEvent('connectedEvent', data);
-    },
-    handleConnectErrorImage(e) {
-      const {  flag, key, index } = e.target.dataset;
-      if (flag === 'pusher') {
-        this.data.pusher.avatar = '../../static/default_avatar.png';
-        this.setData({
-          pusher: this.data.pusher,
-        });
-      } else {
-        this.data[key][index].avatar = '../../static/default_avatar.png';
-        if (this.data.playerList[index]) {
-          this.data.playerList[index].avatar = '../../static/default_avatar.png';
-        }
-        this.setData({
-          playerList: this.data.playerList,
-          [key]: this.data[key],
-        });
-      }
-    },
-  },
-});

+ 0 - 4
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.json

@@ -1,4 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {}
-}

+ 0 - 118
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.wxml

@@ -1,118 +0,0 @@
-<view class="TUICalling-connected-layout {{callType === 1 ? 'audio' : 'video'}}">
-    <view
-        class="{{callType === 1 ? 'pusher-audio' : playerList.length > 1 ? 'stream-box' : (screen === 'pusher' ? 'pusher-video' : 'player')}}"
-        data-screen="pusher" catch:tap="toggleViewSize">
-        <live-pusher class="{{callType === 1 ? 'pusher-audio' : 'live'}}" url="{{pusher.url}}" mode="{{pusher.mode}}"
-            autopush="{{true}}" enable-camera="{{pusher.enableCamera}}" enable-mic="{{true}}"
-            muted="{{!pusher.enableMic}}" enable-agc="{{true}}" enable-ans="{{true}}"
-            enable-ear-monitor="{{pusher.enableEarMonitor}}" auto-focus="{{pusher.enableAutoFocus}}"
-            zoom="{{pusher.enableZoom}}" min-bitrate="{{pusher.minBitrate}}" max-bitrate="{{pusher.maxBitrate}}"
-            video-width="{{pusher.videoWidth}}" video-height="{{pusher.videoHeight}}" beauty="{{pusher.beautyLevel}}"
-            whiteness="{{pusher.whitenessLevel}}" orientation="{{pusher.videoOrientation}}"
-            aspect="{{pusher.videoAspect}}" device-position="{{pusher.frontCamera}}"
-            remote-mirror="{{pusher.enableRemoteMirror}}" local-mirror="{{pusher.localMirror}}"
-            background-mute="{{pusher.enableBackgroundMute}}" audio-quality="{{pusher.audioQuality}}"
-            audio-volume-type="{{pusher.audioVolumeType}}" audio-reverb-type="{{pusher.audioReverbType}}"
-            waiting-image="{{pusher.waitingImage}}" beauty-style="{{pusher.beautyStyle}}" filter="{{pusher.filter}}"
-            bindstatechange="pusherStateChangeHandler" bindnetstatus="pusherNetStatus" binderror="pusherErrorHandler"
-            bindaudiovolumenotify="pusherAudioVolumeNotify" />
-    </view>
-    <view wx:if="{{callType === 1}}" class="TRTCCalling-call-audio-box {{playerList.length > 1 && 'mutil-img'}}">
-        <view class="TRTCCalling-call-audio-img" wx:if="{{playerList.length > 1}}">
-            <image src="{{pusher.avatar || '../../static/default_avatar.png'}}" class="img-place-holder avatar"
-                data-value="{{pusher.userID}}" data-flag="pusher" binderror="handleConnectErrorImage" />
-            <text class="audio-name">{{pusher.nick || pusher.userID}}(自己)</text>
-        </view>
-        <view class="TRTCCalling-call-audio-img" wx:for="{{userList || playerList}}" wx:key="userID">
-            <image src="{{item.avatar || '../../static/default_avatar.png'}}" class="img-place-holder avatar"
-                data-value="{{item}}" data-flag="player" data-key="userList" data-index="{{index}}" binderror="handleConnectErrorImage" />
-            <text class="audio-name">{{item.nick || item.userID}}</text>
-        </view>
-    </view>
-    <view wx:for="{{playerList}}" wx:key="streamID"
-        class="view-container player-container {{callType === 1 ? 'player-audio' : ''}}">
-        <view
-            class="{{callType === 1 ? 'player-audio' : playerList.length > 1 ? 'stream-box' : (screen === 'player' ? 'pusher-video' : 'player')}}"
-            data-screen="player" catch:tap="toggleViewSize">
-            <live-player class="live" wx:if="{{ item.hasAudio || item.hasVideo }}" id="{{item.id}}" data-userid="{{item.userID}}" data-streamid="{{item.streamID}}"
-                data-streamtype="{{item.streamType}}" src="{{item.src}}" mode="RTC" autoplay="{{item.autoplay}}"
-                mute-audio="{{item.muteAudio}}" mute-video="{{item.muteVideo}}" orientation="{{item.orientation}}"
-                object-fit="{{item.objectFit}}" background-mute="{{item.enableBackgroundMute}}"
-                min-cache="{{item.minCache}}" max-cache="{{item.maxCache}}" sound-mode="{{soundMode}}"
-                enable-recv-message="{{item.enableRecvMessage}}" auto-pause-if-navigate="{{item.autoPauseIfNavigate}}"
-                auto-pause-if-open-native="{{item.autoPauseIfOpenNative}}" bindstatechange="playerStateChange"
-                bindfullscreenchange="playerFullscreenChange" bindnetstatus="playNetStatus"
-                bindaudiovolumenotify="playerAudioVolumeNotify" />
-        </view>
-    </view>
-    <view class="handle-btns">
-        <view class="other-view {{callType === 1 ? 'black' : 'white'}}">
-            <text>{{pusher.chatTime}}</text>
-        </view>
-        <view class="btn-operate-item call-switch" catch:tap="switchAudioCall">
-            <view class="call-operate">
-                <image src="../../static/trans.png" />
-            </view>
-            <text>切到语音通话</text>
-        </view>
-        <view class="btn-list">
-            <view class="button-container">
-                <view class="btn-normal" bindtap="pusherAudioHandler">
-                    <image class="btn-image"
-                        src="{{pusher.enableMic? '../../static/audio-true.png': '../../static/audio-false.png'}} ">
-                    </image>
-                </view>
-                <view class="{{callType === 2 ? 'white' : ''}}">麦克风</view>
-            </view>
-            <view class="button-container" wx:if="{{callType === 1}}">
-                <view class="btn-hangup" bindtap="hangup">
-                    <image class="btn-image" src="../../static/hangup.png"></image>
-                </view>
-
-                <view class="{{callType === 2 ? 'white' : ''}}">挂断</view>
-            </view>
-            <view class="button-container">
-                <view class="btn-normal" bindtap="toggleSoundMode">
-                    <image class="btn-image"
-                        src="{{soundMode === 'ear' ? '../../static/speaker-false.png': '../../static/speaker-true.png'}} ">
-                    </image>
-                </view>
-                <text class="{{callType === 2 ? 'white' : ''}}">扬声器</text>
-            </view>
-
-            <view class="button-container" wx:if="{{callType === 2}}">
-                <view class="btn-normal" bindtap="pusherVideoHandler">
-                    <image class="btn-image"
-                        src="{{pusher.enableCamera ? '../../static/camera-true.png': '../../static/camera-false.png'}} ">
-                    </image>
-                </view>
-                <text class="white">摄像头</text>
-            </view>
-        </view>
-        <view class="btn-list" wx:if="{{callType===2}}">
-            <!-- <view class="btn-list-item">
-                <view wx:if="{{playerList.length === 1}}" class="btn-normal" bindtap="switchAudioCall">
-                    <image class="btn-image btn-image-small" src="{{ '../../static/trans.png'}} "></image>
-                </view>
-            </view> -->
-            <view class="btn-list-item other-view">
-                <view class="btn-container">
-                    <view class="btn-hangup" bindtap="hangup">
-                        <image class="btn-image" src="../../static/hangup.png"></image>
-                    </view>
-                    <view wx:if="{{pusher.enableCamera}}" class="invite-calling-header-left">
-                        <image src="../../static/switch_camera.png" data-device="{{pusher.frontCamera}}"
-                            catch:tap="toggleSwitchCamera" />
-                    </view>
-                </view>
-                <text class="white">挂断</text>
-            </view>
-            <!-- <view class="btn-list-item btn-footer">
-                <view wx:if="{{pusher.enableCamera}}" class="{{playerList.length > 1 ? 'multi-camera' : 'camera'}}">
-                    <image class="camera-image" src="../../static/swtich-camera.png"
-                        data-device="{{pusher.frontCamera}}" catch:tap="toggleSwitchCamera" />
-                </view>
-            </view> -->
-        </view>
-    </view>
-</view>

+ 0 - 253
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/connected/connected.wxss

@@ -1,253 +0,0 @@
-.player {
-    position: absolute;
-    right: 16px;
-    top: 107px;
-    width: 100px;
-    height: 178px;
-    padding: 16px;
-    z-index: 3;
-}
-
-.pusher-video {
-    position: absolute;
-    width: 100%;
-    height: 100%;
-    /* background-color: #f75c45; */
-    z-index: 1;
-}
-
-.stream-box {
-    position: relative;
-    float: left;
-    width: 50vw;
-    height: 260px;
-    /* background-color: #f75c45; */
-    z-index: 3;
-}
-
-.handle-btns {
-    position: absolute;
-    bottom: 44px;
-    width: 100vw;
-    z-index: 3;
-    display: flex;
-    flex-direction: column;
-}
-
-.handle-btns .btn-list {
-    display: flex;
-    flex-direction: row;
-    justify-content: space-around;
-    align-items: center;
-}
-
-.button-container {
-    display: flex;
-    flex-direction: column;
-    text-align: center;
-}
-
-.btn-normal {
-    width: 8vh;
-    height: 8vh;
-    box-sizing: border-box;
-    display: flex;
-    flex-direction: column;
-    /* background: white; */
-    justify-content: center;
-    align-items: center;
-    border-radius: 50%;
-}
-
-.btn-image {
-    width: 100%;
-    height: 100%;
-    background: none;
-}
-
-.btn-hangup {
-    width: 8vh;
-    height: 8vh;
-    /*background: #f75c45;*/
-    box-sizing: border-box;
-    display: flex;
-    justify-content: center;
-    align-items: center;
-    border-radius: 50%;
-}
-
-.btn-hangup > .btn-image {
-    width: 100%;
-    height: 100%;
-    background: none;
-}
-
-.TRTCCalling-call-audio {
-    width: 100%;
-    height: 100%;
-}
-
-.btn-footer {
-    position: relative;
-}
-
-.btn-footer .multi-camera {
-    width: 32px;
-    height: 32px;
-}
-
-.btn-footer .camera {
-    width: 64px;
-    height: 64px;
-    position: fixed;
-    left: 16px;
-    top: 107px;
-    display: flex;
-    justify-content: center;
-    align-items: center;
-    background: rgba(255, 255, 255, 0.7);
-}
-
-.btn-footer .camera .camera-image {
-    width: 32px;
-    height: 32px;
-}
-
-.TUICalling-connected-layout {
-    width: 100%;
-    height: 100%;
-}
-
-.audio {
-    padding-top: 15vh;
-    background: #ffffff;
-}
-
-.pusher-audio {
-    width: 0;
-    height: 0;
-}
-
-.player-audio {
-    width: 0;
-    height: 0;
-}
-
-.live {
-    width: 100%;
-    height: 100%;
-}
-
-.other-view {
-    display: flex;
-    flex-direction: column;
-    align-items: center;
-    font-size: 18px;
-    letter-spacing: 0;
-    font-weight: 400;
-    padding: 16px;
-}
-
-.white {
-    color: #f0e9e9;
-    padding: 5px;
-    font-size: 14px;
-}
-
-.black {
-    color: #000000;
-    padding: 5px;
-}
-
-.TRTCCalling-call-audio-box {
-    display: flex;
-    flex-wrap: wrap;
-    justify-content: center;
-}
-
-.mutil-img {
-    justify-content: flex-start !important;
-}
-
-.TRTCCalling-call-audio-img {
-    display: flex;
-    flex-direction: column;
-    align-items: center;
-}
-
-.TRTCCalling-call-audio-img > image {
-    width: 25vw;
-    height: 25vw;
-    margin: 0 4vw;
-    border-radius: 4vw;
-    position: relative;
-}
-
-.TRTCCalling-call-audio-img text {
-    font-size: 20px;
-    color: #333333;
-    letter-spacing: 0;
-    font-weight: 500;
-}
-
-.btn-list-item {
-    flex: 1;
-    display: flex;
-    justify-content: center;
-    padding: 16px 0;
-}
-
-.btn-image-small {
-    transform: scale(.7);
-}
-
-.avatar {
-    background: #dddddd;
-}
-
-.btn-container {
-    display: flex;
-    align-items: center;
-    position: relative;
-}
-
-.invite-calling-header-left {
-    position: absolute;
-    right: -88px;
-}
-
-.invite-calling-header-left image {
-    width: 32px;
-    height: 32px;
-}
-
-.call-switch .call-operate {
-    width: 4vh;
-    height: 3vh;
-}
-
-.call-operate image {
-  width: 100%;
-  height: 100%;
-  background: none;
-}
-
-.call-switch text {
-    padding: 0;
-    font-size: 14px;
-}
-
-.btn-operate-item {
-    display: flex;
-    flex-direction: column;
-    align-items: center;
-}
-
-.btn-operate-item text {
-    padding: 8px 0;
-    font-size: 18px;
-    color: #FFFFFF;
-    letter-spacing: 0;
-    font-weight: 400;
-    font-size: 14px;
-}

+ 0 - 112
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/groupCalling/groupCalling.js

@@ -1,112 +0,0 @@
-// components/tui-calling/TUICalling/component/calling.js
-Component({
-  /**
-   * 组件的属性列表
-   */
-  properties: {
-    isSponsor: {
-      type: Boolean,
-    },
-    pusher: {
-      type: Object,
-    },
-    callType: {
-      type: Number,
-    },
-    allUsers: {
-      type: Array,
-    },
-    isGroup: {
-      type: Boolean,
-    },
-    ownUserId: {
-      type: String,
-    },
-  },
-
-  /**
-   * 组件的初始数据
-   */
-  data: {
-    userID: null,
-  },
-
-  /**
-   * 生命周期方法
-   */
-  lifetimes: {
-    created() {
-    },
-    attached() {
-    },
-    ready() {
-
-    },
-    detached() {
-
-    },
-    error() {
-    },
-  },
-
-  /**
-   * 组件的方法列表
-   */
-  methods: {
-    accept(event) {
-      const data = {
-        name: 'accept',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    hangup(event) {
-      const data = {
-        name: 'hangup',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    reject(event) {
-      const data = {
-        name: 'reject',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    handleErrorImage(e) {
-      const { id } = e.target;
-      const allUsers = this.data.allUsers.map((item) => {
-        if (item.userID === id) {
-          item.avatar = '../../static/default_avatar.png';
-        }
-        return item;
-      });
-      this.setData({
-        allUsers,
-      });
-    },
-    toggleSwitchCamera(event) {
-      const data = {
-        name: 'toggleSwitchCamera',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    switchAudioCall(event) {
-      const data = {
-        name: 'switchAudioCall',
-        event,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-    pusherErrorHandler(event) {
-      const { detail = '' } = event;
-      const data = {
-        name: 'pusherErrorHandler',
-        event: detail,
-      };
-      this.triggerEvent('callingEvent', data);
-    },
-  },
-});

+ 0 - 4
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/groupCalling/groupCalling.json

@@ -1,4 +0,0 @@
-{
-  "component": true,
-  "usingComponents": {}
-}

+ 0 - 135
unpackage/dist/dev/mp-weixin/node_modules/@tencentcloud/call-uikit-wechat/TUICallKit/component/groupCalling/groupCalling.wxml

@@ -1,135 +0,0 @@
-    <!-- 视频通话 -->
-    <view class="invite-call transition-animation" wx:if="{{callType === 2}}">
-        <live-pusher class="local-video" wx:if="{{isGroup===false}}" device-position="{{pusher.frontCamera}}" binderror="pusherErrorHandler"/>
-        <view class="invite-calling">
-            <!-- 主叫方 -->
-            <swiper class="swiper" wx:if="{{isSponsor}}" indicator-dots="{{allUsers.length/4 > 1}}" indicator-color="white" indicator-active-color="black">
-                <block wx:for="{{(allUsers.length)/4}}" wx:key="*this" wx:for-index="pos">
-                    <swiper-item class="invite-calling-list">
-                        <view wx:for="{{allUsers}}" wx:key="userID" class="invite-calling-item" wx:if="{{index >= pos*4 && index < pos*4+4}}">
-                            <view id="{{item.userID}}" class="invite-calling-item-message" wx:if="{{item.userID !== ownUserId}}">
-                                <view class="invite-calling-item-loadimg">
-                                    <image src="../../static/loading.png"></image>
-                                </view>
-                                <view class="invite-calling-item-id">{{item.nick || item.userID}}</view>
-                            </view>
-                            <image class="avatar" src="{{item.avatar || '../../static/default_avatar.png'}}" binderror="handleErrorImage" />
-                            <view class="invite-calling-item-id">{{item.nick || item.userID}}</view>
-                        </view>
-                    </swiper-item>
-                </block>
-            </swiper>
-            <!-- 被叫方 -->
-            <view wx:else>
-                <view class="invite-calling-single">
-                    <image class="avatar" src="{{allUsers[0].avatar || '../../static/default_avatar.png'}}" id="{{allUsers[0].userID}}" binderror="handleErrorImage" />
-                    <view class="tips">{{allUsers[0].nick || allUsers[0].userID }}</view>
-                    <view class="invite-txt">邀请你参加多人通话</view>
-                </view>
-                <view class="invite-other-txt">参与通话的还有:</view>
-                <view class="invite-other-list">
-                    <view class="invite-other-item" wx:if="{{index>0}}" wx:for="{{allUsers}}" wx:key="item">
-                        <image class="avatar" src="{{item.avatar || '../../static/default_avatar.png'}}" binderror="handleErrorImage" />
-                        <view class="invite-other-item-name">{{ item.nick || item.userID}}</view>
-                    </view>
-                </view>
-            </view>
-            <view class="footer">
-                <!-- <view class="btn-operate" wx:if="{{isSponsor}}">
-                <view class="btn-operate-item call-switch" catch:tap="switchAudioCall">
-                    <view class="call-operate">
-                        <image src="../../static/trans.png" />
-                    </view>
-                    <text>切到语音通话</text>
-                </view>
-            </view> -->
-                <view class="btn-operate" wx:if="{{isSponsor}}">
-                    <view class="btn-operate-item">
-                        <view class="btn-container">
-                            <view class="call-operate" catch:tap="hangup">
-                                <image src="../../static/hangup.png" />
-                            </view>
-                            <!-- <view class="invite-calling-header-left">
-                                <image src="../../static/switch_camera.png" data-device="{{pusher.frontCamera}}" catch:tap="toggleSwitchCamera" />
-                            </view> -->
-                        </view>
-                        <text style="color: #666666">挂断</text>
-                    </view>
-                </view>
-                <view class="btn-operate" wx:if="{{!isSponsor}}">
-                    <view class="btn-operate-item">
-                        <view class="call-operate" style="background-color: red" catch:tap="reject">
-                            <image src="../../static/hangup.png" />
-                        </view>
-                        <text style="color: #666666">挂断</text>
-                    </view>
-                    <view class="btn-operate-item">
-                        <view class="call-operate" catch:tap="accept">
-                            <image src="../../static/dialing.png" />
-                        </view>
-                        <text style="color: #666666">接听</text>
-                    </view>
-                </view>
-            </view>
-        </view>
-    </view>
-    <!-- 语音通话 -->
-    <view class="incoming-call audio-call transition-animation" wx:if="{{callType === 1}}">
-        <!-- 主叫方 -->
-        <swiper class="swiper" wx:if="{{isSponsor}}" indicator-dots="{{allUsers.length/4 > 1}}" indicator-color="white" indicator-active-color="black">
-            <block wx:for="{{(allUsers.length)/4}}" wx:key="*this" wx:for-index="pos">
-                <swiper-item class="invite-calling-list">
-                    <view wx:for="{{allUsers}}" wx:key="userID" class="invite-calling-item" wx:if="{{index >= pos*4 && index < pos*4+4}}">
-                        <view id="{{item.userID}}" class="invite-calling-item-message" wx:if="{{item.userID !== ownUserId}}">
-                            <view class="invite-calling-item-loadimg">
-                                <image src="../../static/loading.png"></image>
-                            </view>
-                            <view class="invite-calling-item-id">{{item.nick || item.userID}}</view>
-                        </view>
-                        <image class="avatar" src="{{item.avatar || '../../static/default_avatar.png'}}" binderror="handleErrorImage" />
-                        <view class="invite-calling-item-id">{{item.nick || item.userID}}</view>
-                    </view>
-                </swiper-item>
-            </block>
-        </swiper>
-        <!-- 被叫方 -->
-        <view wx:else>
-            <view class="invite-calling-single">
-                <image class="avatar" src="{{allUsers[0].avatar || '../../static/default_avatar.png'}}" id="{{allUsers[0].userID}}" binderror="handleErrorImage" />
-                <view class="tips">{{allUsers[0].nick || allUsers[0].userID  }}</view>
-                <view class="invite-txt">邀请你参加多人通话</view>
-            </view>
-            <view class="invite-other-txt">参与通话的还有:</view>
-            <view class="invite-other-list">
-                <view class="invite-other-item" wx:if="{{index>0}}" wx:for="{{allUsers}}" wx:key="item">
-                    <image class="avatar" src="{{item.avatar || '../../static/default_avatar.png'}}" binderror="handleErrorImage" />
-                    <view class="invite-other-item-name">{{item.nick || item.userID}}</view>
-                </view>
-            </view>
-        </view>
-        <!-- 菜单 -->
-        <view class="footer">
-            <view wx:if="{{!isSponsor && callType === 1}}" class="btn-operate">
-                <view class="button-container">
-                    <view class="call-operate" style="background-color: red" catch:tap="reject">
-                        <image src="../../static/hangup.png" />
-                    </view>
-                    <view style="margin-top:10px;color: #666666">挂断</view>
-                </view>
-                <view class="button-container">
-                    <view class="call-operate" catch:tap="accept">
-                        <image src="../../static/dialing.png" />
-                    </view>
-                    <view style="margin-top:10px;color: #666666">接听</view>
-                </view>
-            </view>
-            <view wx:if="{{isSponsor && callType === 1}}" class="btn-operate">
-                <view class="button-container">
-                    <view class="call-operate" style="background-color: red" catch:tap="hangup">
-                        <image src="../../static/hangup.png" />
-                    </view>
-                    <view style="margin-top:10px;color: #666666">挂断</view>
-                </view>
-            </view>
-        </view>
-    </view>

Some files were not shown because too many files changed in this diff