ソースを参照

修首页权限

Alex 10 ヶ月 前
コミット
99930a9eb3
100 ファイル変更1101 行追加9215 行削除
  1. 2 19
      App.vue
  2. 8 2
      components/cy-upload/index.vue
  3. 1 1
      config/request.js
  4. 3 1
      main.js
  5. 3 2
      manifest.json
  6. 5 2
      pages/book/components/feedbackPopup.vue
  7. 5 1
      pages/book/index.vue
  8. 32 30
      pages/index/audit/confirm-receipt.vue
  9. 5 1
      pages/index/audit/express-order.vue
  10. 4 1
      pages/index/audit/scan-order.vue
  11. 1 0
      pages/index/detail/batch-audit.vue
  12. 1 0
      pages/index/detail/book-audit.vue
  13. 3 12
      pages/index/detail/components/BookInfo.vue
  14. 4 2
      pages/index/detail/index.vue
  15. 4 1
      pages/index/entry/book-weight.vue
  16. 4 1
      pages/index/entry/scan-book.vue
  17. 4 1
      pages/index/express/quick-check.vue
  18. 5 1
      pages/index/express/quick-unpack.vue
  19. 4 1
      pages/index/express/route-exception.vue
  20. 5 1
      pages/index/express/transfer-sign.vue
  21. 5 1
      pages/index/express/warehouse-sign.vue
  22. 5 1
      pages/index/express/weight-modify.vue
  23. 249 209
      pages/index/index.vue
  24. 4 1
      pages/index/offline/check-order.vue
  25. 5 1
      pages/index/wms/bad-in.vue
  26. 8 4
      pages/index/wms/bad-out-order.vue
  27. 35 22
      pages/index/wms/bad-out.vue
  28. 5 1
      pages/index/wms/location-order-list.vue
  29. 5 1
      pages/index/wms/location-order.vue
  30. 4 1
      pages/index/wms/location-select.vue
  31. 4 1
      pages/index/wms/order-query-list.vue
  32. 4 1
      pages/index/wms/order-query.vue
  33. 4 1
      pages/index/wms/speedy-check.vue
  34. 4 1
      pages/index/wms/task-detail.vue
  35. 231 192
      pages/login/login.vue
  36. 1 1
      unpackage/dist/build/app-plus/app-config-service.js
  37. 0 0
      unpackage/dist/build/app-plus/app-service.js
  38. 2 1
      unpackage/dist/build/app-plus/manifest.json
  39. 0 0
      unpackage/dist/build/app-plus/pages/book/index.css
  40. 0 0
      unpackage/dist/build/app-plus/pages/index/audit/confirm-receipt.css
  41. 0 0
      unpackage/dist/build/app-plus/pages/index/audit/express-order.css
  42. 0 0
      unpackage/dist/build/app-plus/pages/index/audit/scan-order.css
  43. 0 0
      unpackage/dist/build/app-plus/pages/index/detail/batch-audit.css
  44. 0 0
      unpackage/dist/build/app-plus/pages/index/detail/book-audit.css
  45. 0 0
      unpackage/dist/build/app-plus/pages/index/detail/index.css
  46. 0 0
      unpackage/dist/build/app-plus/pages/index/entry/scan-book.css
  47. 0 0
      unpackage/dist/build/app-plus/pages/index/express/quick-check.css
  48. 0 0
      unpackage/dist/build/app-plus/pages/index/express/quick-unpack.css
  49. 0 0
      unpackage/dist/build/app-plus/pages/index/express/route-exception.css
  50. 0 0
      unpackage/dist/build/app-plus/pages/index/express/transfer-sign.css
  51. 0 0
      unpackage/dist/build/app-plus/pages/index/express/warehouse-sign.css
  52. 0 0
      unpackage/dist/build/app-plus/pages/index/express/weight-modify.css
  53. 1 1
      unpackage/dist/build/app-plus/pages/index/index.css
  54. 0 0
      unpackage/dist/build/app-plus/pages/index/offline/check-order.css
  55. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/bad-in.css
  56. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/bad-out-order.css
  57. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/bad-out.css
  58. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/location-order-list.css
  59. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/location-order.css
  60. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/location-select.css
  61. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/order-query-list.css
  62. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/order-query.css
  63. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/speedy-check.css
  64. 0 0
      unpackage/dist/build/app-plus/pages/index/wms/task-detail.css
  65. 0 0
      unpackage/dist/build/app-plus/pages/login/login.css
  66. 1 1
      unpackage/dist/dev/app-plus/app-config-service.js
  67. 268 70
      unpackage/dist/dev/app-plus/app-service.js
  68. 2 1
      unpackage/dist/dev/app-plus/manifest.json
  69. 6 3
      unpackage/dist/dev/app-plus/pages/index/index.css
  70. 145 0
      unpackage/dist/dev/app-plus/pages/index/wms/bad-out.css
  71. 0 171
      unpackage/dist/dev/mp-weixin/app.js
  72. 0 31
      unpackage/dist/dev/mp-weixin/app.json
  73. 0 426
      unpackage/dist/dev/mp-weixin/app.wxss
  74. 0 7247
      unpackage/dist/dev/mp-weixin/common/vendor.js
  75. 0 3
      unpackage/dist/dev/mp-weixin/config/api.js
  76. 0 58
      unpackage/dist/dev/mp-weixin/config/hooks.js
  77. 0 46
      unpackage/dist/dev/mp-weixin/config/request.js
  78. 0 33
      unpackage/dist/dev/mp-weixin/config/share.js
  79. 0 24
      unpackage/dist/dev/mp-weixin/pages/home/home.js
  80. 0 4
      unpackage/dist/dev/mp-weixin/pages/home/home.json
  81. 0 1
      unpackage/dist/dev/mp-weixin/pages/home/home.wxml
  82. 0 30
      unpackage/dist/dev/mp-weixin/pages/home/home.wxss
  83. 0 17
      unpackage/dist/dev/mp-weixin/pages/my/my.js
  84. 0 4
      unpackage/dist/dev/mp-weixin/pages/my/my.json
  85. 0 1
      unpackage/dist/dev/mp-weixin/pages/my/my.wxml
  86. 0 0
      unpackage/dist/dev/mp-weixin/pages/my/my.wxss
  87. 0 148
      unpackage/dist/dev/mp-weixin/static/css/mystyle.css
  88. BIN
      unpackage/dist/dev/mp-weixin/static/imgs/home-a.png
  89. BIN
      unpackage/dist/dev/mp-weixin/static/imgs/home.png
  90. BIN
      unpackage/dist/dev/mp-weixin/static/imgs/my-a.png
  91. BIN
      unpackage/dist/dev/mp-weixin/static/imgs/my.png
  92. 0 6
      unpackage/dist/dev/mp-weixin/store/index.js
  93. 0 34
      unpackage/dist/dev/mp-weixin/store/uses.js
  94. 0 51
      unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/index.js
  95. 0 15
      unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/color.js
  96. 0 35
      unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/config.js
  97. 0 183
      unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props.js
  98. 0 18
      unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props/actionSheet.js
  99. 0 18
      unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props/album.js
  100. 0 15
      unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props/alert.js

+ 2 - 19
App.vue

@@ -1,7 +1,7 @@
 <script setup>
 import { onLaunch, onShow, onHide, onUnload } from "@dcloudio/uni-app";
 import { store } from "@/store/index.js";
-import { useGlobalEventRemove, useInit } from "@/utils/useBarcodeModule.js";
+import { useGlobalEventRemove, useInit, updateActivePageOnShow } from "@/utils/useBarcodeModule.js";
 import { useRouteMonitor } from "@/utils/useRouteMonitor.js";
 import { playClickSound } from "@/config/audioUtil.js";
 
@@ -9,7 +9,6 @@ import { playClickSound } from "@/config/audioUtil.js";
 let touchHandler;
 
 onLaunch(() => {
-    console.log("App Launch");
     // 尝试去获取本地的 token 和用户信息,填充到 store 中
     if (!store.token) {
         let token = uni.getStorageSync("token");
@@ -26,7 +25,6 @@ onLaunch(() => {
 
     // 移动端触摸事件处理函数
     touchHandler = (e) => {
-        console.log("touchHandler", e);
         playClickSound();
     };
 
@@ -43,22 +41,7 @@ onLaunch(() => {
     useInit();
     // #endif
 });
-onShow(() => {
-    // #ifdef APP-PLUS
-    // 页面显示时重新添加全局监听
-    useRouteMonitor((url, from) => {
-        console.log("onShow", url, from);
-        // #ifdef APP-PLUS
-        // 页面隐藏时移除全局监听
-        useGlobalEventRemove();
-        // #endif
-    });
-    // #endif
-});
-
-onHide(() => {
-    console.log("App Hide");
-});
+onShow(() => {});
 
 // 在应用销毁时移除点击事件监听
 onUnload(() => {

+ 8 - 2
components/cy-upload/index.vue

@@ -11,7 +11,7 @@
 		ref
 	} from 'vue';
 	import baseUrl from '@/config/request.js';
-	const emit = defineEmits(['update:filename', 'update:keyValue', 'success'])
+	const emit = defineEmits(['update:filename', 'update:keyValue', 'success','update:loading'])
 
 	const props = defineProps({
 		filename: {
@@ -35,7 +35,11 @@
 		isUpdate: {
 			type: Boolean,
 			default: false
-		}
+		},
+        loading:{
+            type:Boolean,
+            default:false
+        }
 	})
 	const fileList = ref([])
 
@@ -64,6 +68,7 @@
 			status: 'uploading',
 			message: '上传中...',
 		});
+        emit('update:loading',true)
 		const result = await uploadFilePromise(file.url);
 		console.log(result, 'result')
 
@@ -78,6 +83,7 @@
 		//更新外部参数
 		emit('update:filename', fileList.value.map(v => v.url))
 		emit('success', result)
+        emit('update:loading',false)
 	}
 
 	const deletePic = (event) => {

+ 1 - 1
config/request.js

@@ -4,7 +4,7 @@ import {
 /**
  * 文档地址:https://uiadmin.net/uview-plus/js/http.html
  */
-const baseUrl = 'http://bk.shuhi.com'
+const baseUrl = 'https://bk.shuhi.com'
 export function initRequest() {
 	console.log('初始化了 http 请求代码')
 	// 初始化请求配置

+ 3 - 1
main.js

@@ -14,7 +14,8 @@ let ttsModule = new VolumeTTS()
 // #ifdef APP
 import {
 	useInit,
-	useGlobalEvent
+	useGlobalEvent,
+    updateActivePageOnShow
 } from './utils/useBarcodeModule'
 useInit()
 // #endif
@@ -43,6 +44,7 @@ import {
 uni.$u.ttsModule = ttsModule
 // #ifdef APP
 uni.$u.useGlobalEvent = useGlobalEvent
+uni.$u.updateActivePageOnShow = updateActivePageOnShow
 // #endif
 
 export function createApp() {

+ 3 - 2
manifest.json

@@ -1,5 +1,5 @@
 {
-    "name" : "PDS",
+    "name" : "书嗨",
     "appid" : "__UNI__65C1C73",
     "description" : "",
     "versionName" : "1.0.1",
@@ -21,7 +21,8 @@
             "Speech" : {},
             "Barcode" : {},
             "Bluetooth" : {},
-            "Webview-x5" : {}
+            "Webview-x5" : {},
+            "Camera" : {}
         },
         /* 应用发布信息 */
         "distribute" : {

+ 5 - 2
pages/book/components/feedbackPopup.vue

@@ -21,7 +21,7 @@
 
                 <!-- 图片上传 -->
                 <u-form-item label="上传照片" prop="imgUrl" :borderBottom="false">
-                    <cy-upload v-model:filename="formData.imgUrl" multiple :maxCount="4">
+                    <cy-upload v-model:filename="formData.imgUrl" multiple :maxCount="4" :loading="loading">
                         <view class="upload-slot">
                             <u-icon name="plus" size="30"></u-icon>
                             <text class="upload-text">上传照片</text>
@@ -33,7 +33,7 @@
             <!-- 按钮组 -->
             <view class="button-group">
                 <u-button type="info" text="取消" :plain="true" @click="handleCancel" :disabled="submitting"></u-button>
-                <u-button type="primary" text="确认" @click="handleConfirm" :loading="submitting"></u-button>
+                <u-button type="primary" text="确认" @click="handleConfirm" :loading="submitting" :disabled="loading"></u-button>
             </view>
         </view>
     </u-popup>
@@ -52,6 +52,9 @@ const formRef = ref(null);
 // 提交状态
 const submitting = ref(false);
 
+// 上传状态
+const loading = ref(false);
+
 // 表单数据
 const formData = reactive({
     feedbackContent: "",

+ 5 - 1
pages/book/index.vue

@@ -37,7 +37,8 @@
 		computed
 	} from 'vue'
 	import {
-		onLoad
+		onLoad,
+		onShow
 	} from '@dcloudio/uni-app'
 	import FeedbackPopup from './components/feedbackPopup.vue';
 
@@ -110,6 +111,9 @@
 		})
 		// #endif
 	})
+	onShow(() => {
+		uni.$u.updateActivePageOnShow()
+	})
 </script>
 
 <style lang="scss" scoped>

+ 32 - 30
pages/index/audit/confirm-receipt.vue

@@ -1,6 +1,5 @@
 <template>
     <view class="container">
-
         <!-- 底部按钮 -->
         <view class="footer">
             <!-- 查询区域 -->
@@ -11,9 +10,14 @@
                 </u-radio-group>
 
                 <view class="search-box">
-                    <u-input custom-style="font-size:32rpx" placeholder-style="fong-size:32rpx" v-model="formData.search"
-                        :placeholder="formData.searchType == '1' ? '扫描/输入订单号' : '扫描/输入物流单号'" border="surround"
-                        clearable>
+                    <u-input
+                        custom-style="font-size:32rpx"
+                        placeholder-style="fong-size:32rpx"
+                        v-model="formData.search"
+                        :placeholder="formData.searchType == '1' ? '扫描/输入订单号' : '扫描/输入物流单号'"
+                        border="surround"
+                        clearable
+                    >
                     </u-input>
                     <u-button color="#c8c8c8" text="查询" @click="handleSubmit" />
                 </view>
@@ -21,7 +25,7 @@
 
             <u-divider></u-divider>
 
-            <view style="display: flex;">
+            <view style="display: flex">
                 <u-button size="large" type="success" text="确认收货扫码" @click="handleScan" />
             </view>
         </view>
@@ -29,34 +33,29 @@
 </template>
 
 <script setup>
-import {
-    ref
-} from 'vue';
-import {
-    onLoad
-} from '@dcloudio/uni-app';
-
+import { ref } from "vue";
+import { onLoad, onShow } from "@dcloudio/uni-app";
 
 const formData = ref({
-    searchType: '2',
-    search: '',
+    searchType: "2",
+    search: "",
 });
 
 // 处理查询
 const handleSubmit = () => {
-    if(!formData.value.search){
-        uni.$u.toast('请扫描/输入物流单号')
-        return
+    if (!formData.value.search) {
+        uni.$u.toast("请扫描/输入物流单号");
+        return;
     }
-    uni.$u.http.post('/app/orderinfo/confirmOrder', formData.value).then(res => {
+    uni.$u.http.post("/app/orderinfo/confirmOrder", formData.value).then((res) => {
         if (res.code == 200) {
-            let text = formData.value.search + '收货成功'
-            uni.$u.ttsModule.speak(text)
+            let text = formData.value.search + "收货成功";
+            uni.$u.ttsModule.speak(text);
         } else {
-            let text = formData.value.search + '订单不存在'
-            uni.$u.ttsModule.speak(text)
+            let text = formData.value.search + "订单不存在";
+            uni.$u.ttsModule.speak(text);
         }
-    })
+    });
 };
 
 // 处理扫码
@@ -65,20 +64,23 @@ const handleScan = () => {
         success: (res) => {
             formData.value.search = res.result;
             handleSubmit();
-        }
+        },
     });
 };
 
 onLoad(() => {
     // #ifdef APP-PLUS
     uni.$u.useGlobalEvent((e) => {
-        formData.value.search = e.barcode
-        handleSubmit()
-    })
+        formData.value.search = e.barcode;
+        handleSubmit();
+    });
     // #endif
-})
+});
+onShow(() => {
+    uni.$u.updateActivePageOnShow();
+});
 </script>
 
 <style lang="scss" scoped>
-@import '../components/common.scss';
-</style>
+@import "../components/common.scss";
+</style>

+ 5 - 1
pages/index/audit/express-order.vue

@@ -33,7 +33,8 @@ import {
     ref
 } from 'vue';
 import {
-    onLoad
+    onLoad,
+    onShow
 } from '@dcloudio/uni-app'
 
 const form = ref({
@@ -81,6 +82,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 4 - 1
pages/index/audit/scan-order.vue

@@ -61,7 +61,7 @@
 import {
     ref
 } from 'vue';
-import { onLoad } from "@dcloudio/uni-app"
+import { onLoad, onShow } from "@dcloudio/uni-app"
 
 // ISBN列表数据
 const isbnList = ref([]);
@@ -152,6 +152,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 1 - 0
pages/index/detail/batch-audit.vue

@@ -184,6 +184,7 @@ onLoad((options) => {
     // #endif
 });
 onShow(() => {
+    uni.$u.updateActivePageOnShow();
     checkUserId.value = uni.getStorageSync("userInfo")?.userId;
     orderDetail.value = uni.getStorageSync("orderDetail");
 });

+ 1 - 0
pages/index/detail/book-audit.vue

@@ -233,6 +233,7 @@ onShow(() => {
         checkUserId.value = uni.getStorageSync("userInfo")?.userId;
         orderDetail.value = uni.getStorageSync("orderDetail");
     }
+    uni.$u.updateActivePageOnShow();
 });
 </script>
 

+ 3 - 12
pages/index/detail/components/BookInfo.vue

@@ -46,24 +46,15 @@ const auditNum = computed(() => {
 })
 
 function handleBookClick(book) {
-    if (props.detail.status == 10) {
-        uni.$u.ttsModule.speak('订单已审核')
+    if (props.detail.status >= 10) {
+        uni.$u.ttsModule.speak('订单已审核完成')
         return
     }
-    //判断是否已经审核完
-    // let auditNum = book.auditCommentList?.length || 0
-    // if (book.num > auditNum) {
+   
     uni.navigateTo({
         url: `/pages/index/detail/book-audit?isbn=${book.isbn}&orderId=${props.detail.orderId}`
     })
     uni.setStorageSync('auditBook', book)
-    // } else {
-    //     uni.showToast({
-    //         title: '该书籍已审核完成',
-    //         icon: 'none'
-    //     })
-    //     uni.$u.ttsModule.speak('该书籍已审核完成')
-    // }
 }
 
 function getAuditCateNum(cate) {

+ 4 - 2
pages/index/detail/index.vue

@@ -245,8 +245,8 @@ function handleScan(isbn) {
         return
     }
 
-    if (orderDetail.value.status == 10) {
-        uni.$u.ttsModule.speak('订单已审核')
+    if (orderDetail.value.status >= 10) {
+        uni.$u.ttsModule.speak('订单已审核完成')
         return
     }
 
@@ -310,7 +310,9 @@ onLoad((option) => {
 
 
 onShow(() => {
+    uni.$u.updateActivePageOnShow()
     getOrderDetail()
+
 })
 </script>
 

+ 4 - 1
pages/index/entry/book-weight.vue

@@ -18,7 +18,7 @@
 
 <script setup>
 import { ref } from 'vue';
-import { onLoad } from '@dcloudio/uni-app'
+import { onLoad, onShow } from '@dcloudio/uni-app'
 
 const customStyle = {
     height: '100rpx',
@@ -86,4 +86,7 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>

+ 4 - 1
pages/index/entry/scan-book.vue

@@ -105,7 +105,7 @@
 
 <script setup>
 import { ref } from "vue";
-import { onLoad } from "@dcloudio/uni-app";
+import { onLoad, onShow } from "@dcloudio/uni-app";
 
 const searchValue = ref("");
 const scannedISBN = ref("");
@@ -157,6 +157,9 @@ onLoad(() => {
     });
     // #endif
 });
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 4 - 1
pages/index/express/quick-check.vue

@@ -75,7 +75,7 @@
 import {
     ref
 } from 'vue';
-import { onLoad } from "@dcloudio/uni-app"
+import { onLoad, onShow } from "@dcloudio/uni-app"
 
 const selectedBatchId = ref('');
 const showBatchSelector = ref(false);
@@ -164,6 +164,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 5 - 1
pages/index/express/quick-unpack.vue

@@ -31,7 +31,8 @@ import {
 } from 'vue';
 import {
     onLoad,
-    onUnload
+    onUnload,
+    onShow
 } from '@dcloudio/uni-app'
 
 //跳转至扫码页面
@@ -107,6 +108,9 @@ onUnload(()=>{
     document.removeEventListener("keyup", keypress);
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 4 - 1
pages/index/express/route-exception.vue

@@ -28,7 +28,7 @@
 import {
     ref,
 } from 'vue';
-import { onLoad } from '@dcloudio/uni-app';
+import { onLoad, onShow } from '@dcloudio/uni-app';
 import ExceptionItem from './components/ExceptionItem.vue';
 import PageScroll from '@/components/pageScroll/index.vue';
 
@@ -80,6 +80,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 5 - 1
pages/index/express/transfer-sign.vue

@@ -29,7 +29,8 @@
 		ref
 	} from 'vue';
 	import {
-		onLoad
+		onLoad,
+		onShow
 	} from '@dcloudio/uni-app'
 	import WarehouseSelector from './components/WarehouseSelector.vue';
 
@@ -99,6 +100,9 @@
 		})
 		// #endif
 	})
+	onShow(() => {
+		uni.$u.updateActivePageOnShow()
+	})
 </script>
 
 <style lang="scss" scoped>

+ 5 - 1
pages/index/express/warehouse-sign.vue

@@ -29,7 +29,8 @@ import {
     ref
 } from 'vue';
 import {
-    onLoad
+    onLoad,
+    onShow
 } from '@dcloudio/uni-app'
 import WarehouseSelector from './components/WarehouseSelector.vue';
 
@@ -99,6 +100,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 5 - 1
pages/index/express/weight-modify.vue

@@ -35,7 +35,8 @@ import {
     reactive
 } from 'vue';
 import {
-    onLoad
+    onLoad,
+    onShow
 } from '@dcloudio/uni-app'
 import cyUpload from '@/components/cy-upload/index.vue'
 
@@ -102,6 +103,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style>

+ 249 - 209
pages/index/index.vue

@@ -1,226 +1,263 @@
 <template>
     <view class="operation-container">
-        <!-- 快递操作区域 -->
-        <view class="section">
-            <view class="section-title">快递</view>
-            <view class="grid-container">
-                <view v-for="(item, index) in expressOperations" :key="index" class="grid-item" :class="item.type"
-                    @click="handleNavigation(item.path)">
-                    {{ item.name }}
-                </view>
-            </view>
-        </view>
 
-        <!-- 审核操作区域 -->
-        <view class="section">
-            <view class="section-title">审核</view>
+        <!-- 直接循环 -->
+        <view class="section" v-for="item in menuData" :key="item.path">
+            <view class="section-title">{{ item.meta.title }}</view>
             <view class="grid-container">
-                <view v-for="(item, index) in auditOperations" :key="index" class="grid-item" :class="item.type"
-                    @click="handleNavigation(item.path)">
-                    {{ item.name }}
+                <view
+                    class="grid-item"
+                    v-for="child in item.children"
+                    :style="{ gridColumn: child.query.span ? 'span 2' : 'span 1' }"
+                    :key="child.path"
+                    :class="child.query.type"
+                    @click="handleNavigation(child.path)"
+                >
+                    {{ formatName(child.meta.title) }}
                 </view>
             </view>
         </view>
+    </view>
+</template>
 
-        <!-- 统计操作区域 -->
-        <view class="section">
-            <view class="section-title">统计</view>
-            <view class="grid-container">
-                <view v-for="(item, index) in statisticsOperations" :key="index" class="grid-item" :class="item.type"
-                    :style="{ gridColumn: item.span ? 'span 2' : 'span 1' }" @click="handleNavigation(item.path)">
-                    {{ item.name }}
-                </view>
-            </view>
-        </view>
+<script setup>
+import { ref, computed, onMounted } from "vue";
+import { onLoad } from "@dcloudio/uni-app";
 
-        <!-- WMS操作区域 -->
-        <view class="section">
-            <view class="section-title">WMS操作</view>
-            <view class="grid-container">
-                <view v-for="(item, index) in wmsOperations" :key="index" class="grid-item" :class="item.type"
-                    :style="{ gridColumn: item.span ? 'span 2' : 'span 1' }" @click="handleNavigation(item.path)">
-                    {{ item.name }}
-                </view>
-            </view>
-        </view>
+// 菜单数据和加载状态
+const menuData = ref([]);
+let menuPromise = null;
 
-        <!-- 线下核单 -->
-        <view class="section">
-            <view class="section-title">线下核单</view>
-            <view class="grid-container">
-                <view v-for="(item, index) in offlineOperations" :key="index" class="grid-item" :class="item.type"
-                    @click="handleNavigation(item.path)">
-                    {{ item.name }}
-                </view>
-            </view>
-        </view>
+//获取权限菜单 - 只调用一次
+async function getMenuList() {
+    // 如果已经有数据,直接返回
+    if (menuData.value && menuData.value.length > 0) {
+        return menuData.value;
+    }
 
-        <!-- 录入信息 -->
-        <view class="section">
-            <view class="section-title">录入信息</view>
-            <view class="grid-container">
-                <view v-for="(item, index) in entryOperations" :key="index" class="grid-item" :class="item.type"
-                    @click="handleNavigation(item.path)">
-                    {{ item.name }}
-                </view>
-            </view>
-        </view>
-    </view>
-</template>
+    // 如果已有一个正在进行的请求,则返回该Promise
+    if (menuPromise) {
+        return menuPromise;
+    }
 
-<script setup>
-import {
-    ref
-} from 'vue'
+    // 创建新的请求
+    menuPromise = uni.$u.http
+        .get("/app/appUser/getRouters")
+        .then((res) => {
+            const data = res.data;
+            menuData.value = data.map((item) => {
+                item.children = item.children.map((child) => {
+                    child.query = JSON.parse(child.query);
+                    return child;
+                });
+                return item;
+            });
+            return data;
+        })
+        .catch((err) => {
+            // 处理错误情况
+            console.error("获取菜单数据失败", err);
+            return [];
+        })
+        .finally(() => {
+            // 请求完成后,重置Promise
+            menuPromise = null;
+        });
+
+    return menuPromise;
+}
+
+//获取按钮权限
+function getButtonList() {
+    uni.$u.http.get("/app/appUser/getInfo").then((res) => {
+        if (res.code == 200) {
+            uni.setStorageSync("buttonList", res.data);
+        }
+    });
+}
+
+// 页面加载时初始化数据
+onLoad(() => {
+    // 显示加载中提示
+    uni.showLoading({
+        title: '加载中...',
+        mask: true
+    });
+    
+    // 初始化菜单和按钮数据
+    Promise.all([getMenuList(), getButtonList()])
+        .finally(() => {
+            // 数据加载完成后,隐藏加载提示
+            uni.hideLoading();
+        });
+});
+
+const formatName = (name) => {
+    if (!name) return "";
+
+    let result = name;
+
+    if (result.includes("\\n\\r")) {
+        result = result.replace(/\\n\\r/g, "\n");
+    }
+
+    return result;
+};
 
 // 快递操作列表
-const expressOperations = ref([{
-    name: '中转\n\r签收',
-    path: '/pages/index/express/transfer-sign',
-    type: 'primary'
-},
-{
-    name: '到仓\n\r签收',
-    path: '/pages/index/express/warehouse-sign',
-    type: 'warning'
-},
-{
-    name: '重量\n\r修改',
-    path: '/pages/index/express/weight-modify',
-    type: 'primary'
-},
-{
-    name: '快递\n\r验收',
-    path: '/pages/index/express/quick-check',
-    type: 'warning'
-},
-{
-    name: '路由签收\n\r异常',
-    path: '/pages/index/express/route-exception',
-    type: 'primary'
-},
-{
-    name: '快递\n\r拆包',
-    path: '/pages/index/express/quick-unpack',
-    type: 'warning'
-},
-])
+const expressOperations = ref([
+    {
+        name: "中转\n\r签收",
+        path: "/pages/index/express/transfer-sign",
+        type: "primary",
+    },
+    {
+        name: "到仓\n\r签收",
+        path: "/pages/index/express/warehouse-sign",
+        type: "warning",
+    },
+    {
+        name: "重量\n\r修改",
+        path: "/pages/index/express/weight-modify",
+        type: "primary",
+    },
+    {
+        name: "快递\n\r验收",
+        path: "/pages/index/express/quick-check",
+        type: "warning",
+    },
+    {
+        name: "路由签收\n\r异常",
+        path: "/pages/index/express/route-exception",
+        type: "primary",
+    },
+    {
+        name: "快递\n\r拆包",
+        path: "/pages/index/express/quick-unpack",
+        type: "warning",
+    },
+]);
 
 // 审核操作列表
-const auditOperations = ref([{
-    name: '确认\n\r收货',
-    path: '/pages/index/audit/confirm-receipt',
-    type: 'primary'
-},
-{
-    name: '扫书\n\r查单',
-    path: '/pages/index/audit/scan-order',
-    type: 'warning'
-},
-{
-    name: '根据快递单\n\r或订单',
-    path: '/pages/index/audit/express-order',
-    type: 'warning'
-},
-{
-    name: '根据\n\r发件人',
-    path: '/pages/index/audit/sender',
-    type: 'primary'
-},
-])
+const auditOperations = ref([
+    {
+        name: "确认\n\r收货",
+        path: "/pages/index/audit/confirm-receipt",
+        type: "primary",
+    },
+    {
+        name: "扫书\n\r查单",
+        path: "/pages/index/audit/scan-order",
+        type: "warning",
+    },
+    {
+        name: "根据快递单\n\r或订单",
+        path: "/pages/index/audit/express-order",
+        type: "warning",
+    },
+    {
+        name: "根据\n\r发件人",
+        path: "/pages/index/audit/sender",
+        type: "primary",
+    },
+]);
 
 // WMS操作列表
-const wmsOperations = ref([{
-    name: '中等\n\r入库',
-    path: '/pages/index/wms/medium-in',
-    type: 'primary'
-},
-{
-    name: '良品\n\r入库',
-    path: '/pages/index/wms/good-in',
-    type: 'warning'
-},
-{
-    name: '次品\n\r入库',
-    path: '/pages/index/wms/secondary-in',
-    type: 'primary'
-},
-{
-    name: '不良\n\r入库',
-    path: '/pages/index/wms/bad-in',
-    type: 'warning'
-},
-{
-    name: '不良\n\r出库',
-    path: '/pages/index/wms/bad-out',
-    type: 'primary'
-},
-{
-    name: '不良\n\r下架',
-    path: '/pages/index/wms/bad-off',
-    type: 'warning'
-},
-{
-    name: '订单\n\r查询',
-    path: '/pages/index/wms/order-query',
-    type: 'primary'
-},
-{
-    name: '库位\n\r订单',
-    path: '/pages/index/wms/location-order',
-    type: 'warning'
-},
-{
-    name: '快速盘点',
-    path: '/pages/index/wms/speedy-check',
-    type: 'primary',
-    span: 24
-},
-])
+const wmsOperations = ref([
+    {
+        name: "中等\n\r入库",
+        path: "/pages/index/wms/medium-in",
+        type: "primary",
+    },
+    {
+        name: "良品\n\r入库",
+        path: "/pages/index/wms/good-in",
+        type: "warning",
+    },
+    {
+        name: "次品\n\r入库",
+        path: "/pages/index/wms/secondary-in",
+        type: "primary",
+    },
+    {
+        name: "不良\n\r入库",
+        path: "/pages/index/wms/bad-in",
+        type: "warning",
+    },
+    {
+        name: "不良\n\r出库",
+        path: "/pages/index/wms/bad-out",
+        type: "primary",
+    },
+    {
+        name: "不良\n\r下架",
+        path: "/pages/index/wms/bad-off",
+        type: "warning",
+    },
+    {
+        name: "订单\n\r查询",
+        path: "/pages/index/wms/order-query",
+        type: "primary",
+    },
+    {
+        name: "库位\n\r订单",
+        path: "/pages/index/wms/location-order",
+        type: "warning",
+    },
+    {
+        name: "快速盘点",
+        path: "/pages/index/wms/speedy-check",
+        type: "primary",
+        span: 24,
+    },
+]);
 
 // 统计操作列表
-const statisticsOperations = ref([{
-    name: '审核统计',
-    path: '/pages/index/statistic/audit',
-    type: 'warning',
-    span: 24
-},
-{
-    name: '售后\n\r统计',
-    path: '/pages/index/statistic/after-sale',
-    type: 'primary'
-},
-{
-    name: '打包\n\r统计',
-    path: '/pages/index/statistic/package',
-    type: 'warning'
-},
-])
+const statisticsOperations = ref([
+    {
+        name: "审核统计",
+        path: "/pages/index/statistic/audit",
+        type: "warning",
+        span: 24,
+    },
+    {
+        name: "售后\n\r统计",
+        path: "/pages/index/statistic/after-sale",
+        type: "primary",
+    },
+    {
+        name: "打包\n\r统计",
+        path: "/pages/index/statistic/package",
+        type: "warning",
+    },
+]);
 //线下核单
-const offlineOperations = ref([{
-    name: '线下\n\r核单',
-    path: '/pages/index/offline/check-order',
-    type: 'primary'
-},
-{
-    name: '核单\n\r记录',
-    path: '/pages/index/offline/check-record',
-    type: 'warning'
-},
-])
+const offlineOperations = ref([
+    {
+        name: "线下\n\r核单",
+        path: "/pages/index/offline/check-order",
+        type: "primary",
+    },
+    {
+        name: "核单\n\r记录",
+        path: "/pages/index/offline/check-record",
+        type: "warning",
+    },
+]);
 
 //录入信息
-const entryOperations = ref([{
-    name: '扫码\n\r查书',
-    path: '/pages/index/entry/scan-book',
-    type: 'primary'
-},
-{
-    name: '录入\n\r书籍重量',
-    path: '/pages/index/entry/book-weight',
-    type: 'warning'
-},
-])
+const entryOperations = ref([
+    {
+        name: "扫码\n\r查书",
+        path: "/pages/index/entry/scan-book",
+        type: "primary",
+    },
+    {
+        name: "录入\n\r书籍重量",
+        path: "/pages/index/entry/book-weight",
+        type: "warning",
+    },
+]);
 
 // 页面跳转方法
 const handleNavigation = (path) => {
@@ -228,12 +265,12 @@ const handleNavigation = (path) => {
         url: path,
         fail: () => {
             uni.showToast({
-                title: '页面跳转失败',
-                icon: 'none',
-            })
+                title: "页面跳转失败",
+                icon: "none",
+            });
         },
-    })
-}
+    });
+};
 </script>
 
 <style lang="scss" scoped>
@@ -250,6 +287,7 @@ const handleNavigation = (path) => {
     background: #ffffff;
     border-radius: 16rpx;
     padding: 20rpx;
+    padding-right: 0;
     box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.05);
 
     .section-title {
@@ -265,11 +303,10 @@ const handleNavigation = (path) => {
     .grid-container {
         display: flex;
         flex-wrap: wrap;
-        gap: 20rpx;
         padding: 10rpx;
 
         .grid-item {
-            flex: 0 0 calc(50% - 10rpx);
+            width: calc(50% - 20rpx);
             min-height: 148rpx;
             display: flex;
             align-items: center;
@@ -283,9 +320,12 @@ const handleNavigation = (path) => {
             transition: all 0.3s;
             white-space: pre-wrap;
             box-sizing: border-box;
+            margin-right: 20rpx;
+            margin-bottom: 20rpx;
 
             &[style*="grid-column: span 2"] {
-                flex: 0 0 100%;
+                width: calc(100% - 20rpx);
+                margin-right: 20rpx;
             }
 
             &.primary {
@@ -310,4 +350,4 @@ const handleNavigation = (path) => {
         }
     }
 }
-</style>
+</style>

+ 4 - 1
pages/index/offline/check-order.vue

@@ -18,7 +18,7 @@
 
 <script setup>
 import { ref, computed } from 'vue';
-import { onLoad } from '@dcloudio/uni-app';
+import { onLoad, onShow } from '@dcloudio/uni-app';
 import BookItem from '../components/BookItemOrder.vue';
 
 const bookList = ref([]);
@@ -84,6 +84,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style scoped>

+ 5 - 1
pages/index/wms/bad-in.vue

@@ -63,8 +63,9 @@ import {
     ref,
     reactive,
     onMounted,
-    onUnmounted
+    onUnmounted,
 } from 'vue';
+import { onShow } from '@dcloudio/uni-app';
 import BadItem from './components/BadItem.vue';
 import VolumeTTS from '@/utils/VolumeTTS.js'
 import RemarkDialog from './components/RemarkDialog.vue'
@@ -247,6 +248,9 @@ onMounted(() => {
         formData.godownId = data.id
     })
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 
 // 记得在页面卸载时移除事件监听
 onUnmounted(() => {

+ 8 - 4
pages/index/wms/bad-out-order.vue

@@ -5,10 +5,10 @@
             <view class="search-area flex-c mb-20">
                 <u-search
                     v-model="searchText"
-                    placeholder="请输入运单号/订单编号"
+                    :placeholder="searchType == '1' ? '请输入订单编号' : '请输入运单号'"
                     :show-action="false"
                     :clearabled="true"
-                    @change="onSearch"
+                    @search="onSearch"
                     height="40"
                 >
                 </u-search>
@@ -28,6 +28,7 @@
                 <view class="info-section">
                     <view class="info-item">库位:{{ locationInfo.positionCode }}</view>
                     <view class="info-item">物流单号:{{ locationInfo.waybillCode || "-" }}</view>
+                    <view class="info-item">退回物流:{{ locationInfo.refundWaybillCode || "-" }}</view>
                     <view class="info-item">订单编号:{{ locationInfo.orderId }}</view>
                     <view class="info-item">订单商品:{{ locationInfo.badNum }}</view>
                     <view class="info-item">备注信息:{{ locationInfo.remark || "-" }}</view>
@@ -66,6 +67,7 @@ import VolumeTTS from "@/utils/VolumeTTS.js";
 import { onLoad } from "@dcloudio/uni-app";
 
 const searchText = ref("");
+const searchType = ref("1");
 const errorMsg = ref("");
 const hasData = ref(false);
 
@@ -76,12 +78,14 @@ const locationInfo = ref({
     orderId: "",
     badNum: "",
     remark: "",
+    refundWaybillCode: "",
 });
 
 // 极差商品列表
 const badList = ref([]);
 
 onLoad((options) => {
+    searchType.value = options.searchType || "1";
     if (options.searchText) {
         searchText.value = options.searchText;
         onSearch();
@@ -104,10 +108,9 @@ const onSearch = async () => {
     }
 
     try {
-        const searchType = getSearchType(searchText.value);
         const res = await uni.$u.http.post("/app/stock/findOrderOutStock", {
             search: searchText.value,
-            searchType: searchType,
+            searchType: searchType.value,
         });
         if (res.code == 200) {
             const data = res.data;
@@ -120,6 +123,7 @@ const onSearch = async () => {
                 orderId: data.orderId || "",
                 badNum: data.badNum || "",
                 remark: data.remark || "",
+                refundWaybillCode: data.refundWaybillCode || "",
             };
             badList.value = data.detailVoList || [];
         } else {

+ 35 - 22
pages/index/wms/bad-out.vue

@@ -6,51 +6,64 @@
         </view>
 
         <!-- 底部搜索框 -->
-        <view class="pad-20 flex-a" style="background: #ffffff;">
-            <u-search v-model="searchText" placeholder="请输入快递单号/订单编号" :show-action="false" :clearabled="true"
-                @change="onSearch" height="40" @click="searchText = ''">
-            </u-search>
-            <u-icon name="scan" size="28" color="#19be6b" @click="openScan"></u-icon>
+        <view class="pad-20 flex flex-column" style="background: #ffffff">
+            <u-radio-group v-model="searchType" class="mb-20 ml-20">
+                <u-radio label="查订单" name="1" label-size="17" />
+                <u-radio label="查物流" custom-style="margin-left:20px" name="2" label-size="17" />
+            </u-radio-group>
+
+            <view class="flex-a">
+                <u-search
+                    v-model="searchText"
+                    placeholder="请输入快递单号/订单编号"
+                    :show-action="false"
+                    :clearabled="true"
+                    @search="onSearch"
+                    height="40"
+                >
+                </u-search>
+                <u-icon name="scan" size="28" color="#19be6b" @click="openScan"></u-icon>
+            </view>
         </view>
     </view>
 </template>
 
 <script setup>
-import { ref, computed, onMounted } from 'vue'
+import { ref, computed, onMounted } from "vue";
 // 搜索文本
-const searchText = ref('')
-
+const searchText = ref("");
+const searchType = ref("1");
 
 // 搜索处理
 const onSearch = () => {
     // 实现搜索逻辑
     uni.navigateTo({
-        url: `/pages/index/wms/bad-out-order?searchText=${searchText.value}`
-    })
-}
+        url: `/pages/index/wms/bad-out-order?searchText=${searchText.value}&searchType=${searchType.value}`,
+    });
+};
 
 // 打开扫码
 const openScan = () => {
     // #ifdef APP-PLUS || MP-WEIXIN
     uni.scanCode({
         success: (res) => {
-            searchText.value = res.result
-            onSearch()
+            searchText.value = res.result;
+            onSearch();
         },
         fail: (err) => {
             uni.showToast({
-                title: '扫码失败',
-                icon: 'error'
-            })
-        }
-    })
+                title: "扫码失败",
+                icon: "error",
+            });
+        },
+    });
     // #endif
 
     // #ifdef H5
     uni.showToast({
-        title: 'H5环境不支持扫码',
-        icon: 'none'
-    })
+        title: "H5环境不支持扫码",
+        icon: "none",
+    });
     // #endif
-}
+};
 </script>

+ 5 - 1
pages/index/wms/location-order-list.vue

@@ -29,7 +29,8 @@ import {
     ref
 } from 'vue'
 import {
-    onLoad
+    onLoad,
+    onShow
 } from '@dcloudio/uni-app'
 import LocationOrderItem from './components/LocationOrderItem.vue'
 
@@ -106,6 +107,9 @@ onLoad((options) => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 5 - 1
pages/index/wms/location-order.vue

@@ -15,7 +15,8 @@ import {
     ref
 } from 'vue'
 import {
-    onLoad
+    onLoad,
+    onShow
 } from '@dcloudio/uni-app'
 
 const positionCode = ref('')
@@ -49,6 +50,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 4 - 1
pages/index/wms/location-select.vue

@@ -21,7 +21,7 @@
 
 <script setup>
 import { ref, computed, onMounted } from 'vue'
-import { onLoad } from '@dcloudio/uni-app'
+import { onLoad, onShow } from '@dcloudio/uni-app'
 // 搜索文本
 const searchText = ref('')
 
@@ -99,6 +99,9 @@ onLoad((opts) => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style scoped>

+ 4 - 1
pages/index/wms/order-query-list.vue

@@ -42,7 +42,7 @@ import {
     reactive,
     ref
 } from 'vue'
-import { onLoad } from '@dcloudio/uni-app'
+import { onLoad, onShow } from '@dcloudio/uni-app'
 import BookInfo from '../detail/components/BookInfo.vue'
 
 const list1 = reactive([{
@@ -125,6 +125,9 @@ onLoad((options) => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 4 - 1
pages/index/wms/order-query.vue

@@ -17,7 +17,7 @@ import {
     reactive,
     ref
 } from 'vue'
-import { onLoad } from '@dcloudio/uni-app'
+import { onLoad, onShow } from '@dcloudio/uni-app'
 
 const query = reactive({
     searchType: 2,
@@ -53,6 +53,9 @@ onLoad(() => {
     })
     // #endif
 })
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style lang="scss" scoped>

+ 4 - 1
pages/index/wms/speedy-check.vue

@@ -122,7 +122,7 @@
 
 <script setup>
 import { reactive, ref } from "vue";
-import { onLoad, onUnload } from "@dcloudio/uni-app";
+import { onLoad, onUnload, onShow } from "@dcloudio/uni-app";
 import LocationOrderItem from "./components/LocationOrderItem.vue";
 
 const goBack = () => {
@@ -323,6 +323,9 @@ onLoad(() => {
     });
     // #endif
 });
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 
 onUnload(() => {
     uni.$off("selectedProducts");

+ 4 - 1
pages/index/wms/task-detail.vue

@@ -87,7 +87,7 @@
 import { ref, onMounted } from "vue";
 import BadOutCard from "@/pages/index/wms/components/BadOutCard.vue";
 import VolumeTTS from "@/utils/VolumeTTS.js";
-import { onLoad, onUnload } from "@dcloudio/uni-app";
+import { onLoad, onUnload, onShow } from "@dcloudio/uni-app";
 
 // 任务进度
 const currentTask = ref(0);
@@ -310,6 +310,9 @@ onLoad((opts) => {
     });
     // #endif
 });
+onShow(() => {
+    uni.$u.updateActivePageOnShow()
+})
 </script>
 
 <style scoped>

+ 231 - 192
pages/login/login.vue

@@ -1,205 +1,244 @@
 <template>
-	<view class="login-container">
-		<!-- Logo和标题区域 -->
-		<view class="logo-section">
-			<image class="logo" src="/static/img/logo.png" mode="aspectFit" />
-		</view>
-
-		<!-- 表单区域 -->
-		<view class="form-section">
-			<u--form :model="formData" ref="uForm">
-				<u-form-item>
-					<u-input :prefixIconStyle="prefixIconStyle" :placeholder-style="placeholderStyle"
-						:custom-style="customStyle" v-model="formData.username" placeholder="请输入用户名"
-						prefixIcon="account" />
-				</u-form-item>
-
-				<u-form-item>
-					<u-input :prefixIconStyle="prefixIconStyle" :placeholder-style="placeholderStyle"
-						:custom-style="customStyle" v-model="formData.password" type="password" placeholder="请输入密码"
-						prefixIcon="lock" />
-				</u-form-item>
-
-				<u-form-item>
-					<u-input :prefixIconStyle="prefixIconStyle" :placeholder-style="placeholderStyle"
-						:custom-style="customStyle" v-model="formData.code" placeholder="请输入验证码" prefixIcon="chat">
-						<template #suffix>
-							<u-button custom-style="width:200rpx" color="#22ac38" size="small" @click="getVerifyCode"
-								:disabled="isCountingDown">
-								{{ countDownText }}
-							</u-button>
-						</template>
-					</u-input>
-				</u-form-item>
-			</u--form>
-
-			<u-button custom-style="margin-top:5%" type="primary" block @click="handleLogin" color="#22ac38"
-				shape="circle">登录</u-button>
-		</view>
-	</view>
+    <view class="login-container">
+        <!-- Logo和标题区域 -->
+        <view class="logo-section">
+            <image class="logo" src="/static/img/logo.png" mode="aspectFit" />
+        </view>
+
+        <!-- 表单区域 -->
+        <view class="form-section">
+            <u--form :model="formData" ref="uForm">
+                <u-form-item>
+                    <u-input
+                        :prefixIconStyle="prefixIconStyle"
+                        :placeholder-style="placeholderStyle"
+                        :custom-style="customStyle"
+                        v-model="formData.username"
+                        placeholder="请输入用户名"
+                        prefixIcon="account"
+                    />
+                </u-form-item>
+
+                <u-form-item>
+                    <u-input
+                        :prefixIconStyle="prefixIconStyle"
+                        :placeholder-style="placeholderStyle"
+                        :custom-style="customStyle"
+                        v-model="formData.password"
+                        type="password"
+                        placeholder="请输入密码"
+                        prefixIcon="lock"
+                    />
+                </u-form-item>
+
+                <u-form-item>
+                    <u-input
+                        :prefixIconStyle="prefixIconStyle"
+                        :placeholder-style="placeholderStyle"
+                        :custom-style="customStyle"
+                        v-model="formData.code"
+                        placeholder="请输入验证码"
+                        prefixIcon="chat"
+                    >
+                        <template #suffix>
+                            <u-button
+                                custom-style="width:200rpx"
+                                color="#22ac38"
+                                size="small"
+                                @click="getVerifyCode"
+                                :disabled="isCountingDown"
+                            >
+                                {{ countDownText }}
+                            </u-button>
+                        </template>
+                    </u-input>
+                </u-form-item>
+            </u--form>
+
+            <u-button
+                custom-style="margin-top:5%"
+                type="primary"
+                block
+                @click="handleLogin"
+                color="#22ac38"
+                shape="circle"
+                >登录</u-button
+            >
+        </view>
+    </view>
 </template>
 
 <script setup>
-	import {
-		ref,
-		reactive,
-		getCurrentInstance,
-	} from 'vue'
-	import {
-		onLoad
-	} from '@dcloudio/uni-app'
-
-	const prefixIconStyle = "font-size:50rpx"
-	const placeholderStyle = "font-size:32rpx"
-	const customStyle = reactive({
-		"font-size": '40rpx',
-		height: '90rpx'
-	})
-
-	let {
-		proxy
-	} = getCurrentInstance()
-
-	const formData = reactive({
-		username: '',
-		password: '',
-		code: ''
-	})
-
-	const uForm = ref(null)
-
-	const isCountingDown = ref(false)
-	const countdown = ref(60)
-	const countDownText = ref('获取验证码')
-
-	const startCountDown = () => {
-		isCountingDown.value = true
-		countdown.value = 60
-		countDownText.value = `${countdown.value}秒重发`
-
-		const timer = setInterval(() => {
-			countdown.value--
-			countDownText.value = `${countdown.value}秒重发`
-
-			if (countdown.value <= 0) {
-				clearInterval(timer)
-				isCountingDown.value = false
-				countDownText.value = '重新发送'
-			}
-		}, 1000)
-	}
-
-	const getVerifyCode = () => {
-		if (isCountingDown.value) return
-		if (!formData.username) return uni.$u.toast('请输入用户名')
-		if (!formData.password) return uni.$u.toast('请输入密码')
-
-		let data = {
-			username: formData.username,
-			password: formData.password
-		}
-		// TODO: 调用发送验证码的API
-		uni.showLoading({
-			mask: true,
-			title: "发送中..."
-		})
-		uni.$u.http.post('/app/appUser/sendMobileCode', data).then(res => {
-			if (res.code == 200) {
-				uni.showToast({
-					title: '验证码发送成功,请注意查收',
-					icon: 'none'
-				})
-				startCountDown()
-			} else {
-				uni.$u.toast(res.msg)
-			}
-		}).finally(() => uni.hideLoading())
-	}
-
-	const handleLogin = () => {
-		// 实现登录逻辑
-		if (!formData.username) return uni.$u.toast('请输入用户名')
-		if (!formData.password) return uni.$u.toast('请输入密码')
-		// if (!formData.code) return uni.$u.toast('请输入验证码')
-
-		// TODO: 调用登录API /app/appUser/login
-		uni.showLoading({
-			mask: true,
-			title: "登录中..."
-		})
-		// /actuator/debug/loginNotCode  ///app/appUser/login
-		uni.$u.http.post('/actuator/debug/loginNotCode', formData).then(res => {
-			if (res.code == 200) {
-				uni.$u.toast('登录成功')
-				uni.switchTab({
-					url: "/pages/index/index"
-				})
-				uni.setStorageSync('token', res.data)
-                getUserInfo()
-				uni.$u.ttsModule.speak('书嗨,不辜负每一个爱书的人')
-			} else {
-				uni.$u.toast(res.msg)
-			}
-		}).finally(() => uni.hideLoading())
-	}
-
-    //获取登陆人信息并存储本地 /app/appUser/getUserInfoById
-    function getUserInfo(){
-        uni.$u.http.get('/app/appUser/getUserInfoById').then(res => {
+import { ref, reactive, getCurrentInstance } from "vue";
+import { onLoad } from "@dcloudio/uni-app";
+
+const prefixIconStyle = "font-size:50rpx";
+const placeholderStyle = "font-size:32rpx";
+const customStyle = reactive({
+    "font-size": "40rpx",
+    height: "90rpx",
+});
+
+let { proxy } = getCurrentInstance();
+
+const formData = reactive({
+    username: "",
+    password: "",
+    code: "",
+});
+
+const uForm = ref(null);
+
+const isCountingDown = ref(false);
+const countdown = ref(60);
+const countDownText = ref("获取验证码");
+
+const startCountDown = () => {
+    isCountingDown.value = true;
+    countdown.value = 60;
+    countDownText.value = `${countdown.value}秒重发`;
+
+    const timer = setInterval(() => {
+        countdown.value--;
+        countDownText.value = `${countdown.value}秒重发`;
+
+        if (countdown.value <= 0) {
+            clearInterval(timer);
+            isCountingDown.value = false;
+            countDownText.value = "重新发送";
+        }
+    }, 1000);
+};
+
+const getVerifyCode = () => {
+    if (isCountingDown.value) return;
+    if (!formData.username) return uni.$u.toast("请输入用户名");
+    if (!formData.password) return uni.$u.toast("请输入密码");
+
+    let data = {
+        username: formData.username,
+        password: formData.password,
+    };
+    // TODO: 调用发送验证码的API
+    uni.showLoading({
+        mask: true,
+        title: "发送中...",
+    });
+    uni.$u.http
+        .post("/app/appUser/sendMobileCode", data)
+        .then((res) => {
             if (res.code == 200) {
-                uni.setStorageSync('userInfo', res.data)
+                uni.showToast({
+                    title: "验证码发送成功,请注意查收",
+                    icon: "none",
+                });
+                startCountDown();
+            } else {
+                uni.$u.toast(res.msg);
             }
         })
-    }
+        .finally(() => uni.hideLoading());
+};
+
+const handleLogin = () => {
+    // 实现登录逻辑
+    if (!formData.username) return uni.$u.toast("请输入用户名");
+    if (!formData.password) return uni.$u.toast("请输入密码");
+    // if (!formData.code) return uni.$u.toast('请输入验证码')
+
+    // TODO: 调用登录API /app/appUser/login
+    uni.showLoading({
+        mask: true,
+        title: "登录中...",
+    });
+    // /actuator/debug/loginNotCode  ///app/appUser/login
+    uni.$u.http
+        .post("/actuator/debug/loginNotCode", formData)
+        .then((res) => {
+            if (res.code == 200) {
+                uni.setStorageSync("token", res.data);
+                getUserInfo();
+                //获取菜单权限
+                uni.$u.http.get("/app/appUser/getRouters").then((resp) => {
+                    if (resp.code == 200) {
+                        uni.setStorageSync("menuList", resp.data);
+
+                        uni.$u.toast("登录成功");
+                        uni.switchTab({
+                            url: "/pages/index/index",
+                        });
+                        uni.$u.ttsModule.speak("书嗨,不辜负每一个爱书的人");
+                    } else {
+                        uni.$u.toast(resp.msg);
+                    }
+                });
+            } else {
+                uni.$u.toast(res.msg);
+            }
+        })
+        .finally(() => uni.hideLoading());
+};
+
+//获取登陆人信息并存储本地 /app/appUser/getUserInfoById
+function getUserInfo() {
+    uni.$u.http.get("/app/appUser/getUserInfoById").then((res) => {
+        if (res.code == 200) {
+            uni.setStorageSync("userInfo", res.data);
+        }
+    });
+}
+
+//检测token是否可用
+function checkToken() {
+    // /app/appUser/checkToken
+    uni.showLoading({
+        title: "检测登录状态...",
+    });
+    uni.$u.http
+        .get("/app/appUser/checkToken")
+        .then((res) => {
+            if (res.code == 200) {
+                uni.$u.toast("登录成功");
+                uni.switchTab({
+                    url: "/pages/index/index",
+                });
+            } else {
+                uni.$u.toast("请先登录");
+            }
+        })
+        .finally(() => uni.hideLoading());
+}
 
-	//检测token是否可用
-	function checkToken() {
-		// /app/appUser/checkToken
-		uni.showLoading({
-			title: "检测登录状态..."
-		})
-		uni.$u.http.get('/app/appUser/checkToken').then(res => {
-			if (res.code == 200) {
-				uni.$u.toast('登录成功')
-				uni.switchTab({
-					url: "/pages/index/index"
-				})
-			} else {
-				uni.$u.toast('请先登录')
-			}
-		}).finally(() => uni.hideLoading())
-	}
-
-	onLoad(() => {
-		let token = uni.getStorageSync('token')
-		if (token) {
-			checkToken()
-		}
-	})
+onLoad(() => {
+    let token = uni.getStorageSync("token");
+    if (token) {
+        checkToken();
+    }
+});
 </script>
 <style>
-	page {
-		background-color: #ffffff;
-	}
+page {
+    background-color: #ffffff;
+}
 </style>
 
 <style lang="scss" scoped>
-	.login-container {
-		padding: 5% 60rpx;
-
-		.logo-section {
-			display: flex;
-			flex-direction: column;
-			align-items: center;
-		}
-
-		.logo {
-			width: 300rpx;
-			height: 300rpx;
-		}
-
-		.form-section {
-			margin-top: 40rpx;
-		}
-	}
-</style>
+.login-container {
+    padding: 5% 60rpx;
+
+    .logo-section {
+        display: flex;
+        flex-direction: column;
+        align-items: center;
+    }
+
+    .logo {
+        width: 300rpx;
+        height: 300rpx;
+    }
+
+    .form-section {
+        margin-top: 40rpx;
+    }
+}
+</style>

ファイルの差分が大きいため隠しています
+ 1 - 1
unpackage/dist/build/app-plus/app-config-service.js


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/app-service.js


+ 2 - 1
unpackage/dist/build/app-plus/manifest.json

@@ -5,7 +5,7 @@
     "iPad"
   ],
   "id": "__UNI__65C1C73",
-  "name": "PDS",
+  "name": "书嗨",
   "version": {
     "name": "1.0.1",
     "code": 101
@@ -21,6 +21,7 @@
     "Barcode": {},
     "Bluetooth": {},
     "Webview-x5": {},
+    "Camera": {},
     "UniNView": {
       "description": "UniNView原生渲染"
     }

ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/book/index.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/audit/confirm-receipt.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/audit/express-order.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/audit/scan-order.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/detail/batch-audit.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/detail/book-audit.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/detail/index.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/entry/scan-book.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/express/quick-check.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/express/quick-unpack.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/express/route-exception.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/express/transfer-sign.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/express/warehouse-sign.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/express/weight-modify.css


+ 1 - 1
unpackage/dist/build/app-plus/pages/index/index.css

@@ -1 +1 @@
-.operation-container[data-v-3becea2b]{padding:.625rem;box-sizing:border-box}.section[data-v-3becea2b]{margin-bottom:.9375rem;background:#fff;border-radius:.5rem;padding:.625rem;box-shadow:0 .0625rem .375rem rgba(0,0,0,.05)}.section .section-title[data-v-3becea2b]{font-size:1.5625rem;font-weight:600;color:#333;padding:.625rem;padding-top:0;border-bottom:.0625rem solid #f0f0f0;margin-bottom:.625rem}.section .grid-container[data-v-3becea2b]{display:flex;flex-wrap:wrap;gap:.625rem;padding:.3125rem}.section .grid-container .grid-item[data-v-3becea2b]{flex:0 0 calc(50% - .3125rem);min-height:4.625rem;display:flex;align-items:center;justify-content:center;text-align:center;padding:.625rem .9375rem;line-height:1.875rem;font-size:1.5625rem;border-radius:.375rem;color:#fff;transition:all .3s;white-space:pre-wrap;box-sizing:border-box}.section .grid-container .grid-item[style*="grid-column: span 2"][data-v-3becea2b]{flex:0 0 100%}.section .grid-container .grid-item.primary[data-v-3becea2b]{background:linear-gradient(135deg,#4cd964,#3ac555)}.section .grid-container .grid-item.primary[data-v-3becea2b]:active{background:linear-gradient(135deg,#3ac555,#2fb548)}.section .grid-container .grid-item.warning[data-v-3becea2b]{background:linear-gradient(135deg,#ff9500,#ff8000)}.section .grid-container .grid-item.warning[data-v-3becea2b]:active{background:linear-gradient(135deg,#ff8000,#e67300)}.section .grid-container .grid-item[data-v-3becea2b]:active{transform:scale(.98)}
+.operation-container[data-v-4129b6d2]{padding:.625rem;box-sizing:border-box}.section[data-v-4129b6d2]{margin-bottom:.9375rem;background:#fff;border-radius:.5rem;padding:.625rem;padding-right:0;box-shadow:0 .0625rem .375rem rgba(0,0,0,.05)}.section .section-title[data-v-4129b6d2]{font-size:1.5625rem;font-weight:600;color:#333;padding:.625rem;padding-top:0;border-bottom:.0625rem solid #f0f0f0;margin-bottom:.625rem}.section .grid-container[data-v-4129b6d2]{display:flex;flex-wrap:wrap;padding:.3125rem}.section .grid-container .grid-item[data-v-4129b6d2]{width:calc(50% - .625rem);min-height:4.625rem;display:flex;align-items:center;justify-content:center;text-align:center;padding:.625rem .9375rem;line-height:1.875rem;font-size:1.5625rem;border-radius:.375rem;color:#fff;transition:all .3s;white-space:pre-wrap;box-sizing:border-box;margin-right:.625rem;margin-bottom:.625rem}.section .grid-container .grid-item[style*="grid-column: span 2"][data-v-4129b6d2]{width:calc(100% - .625rem);margin-right:.625rem}.section .grid-container .grid-item.primary[data-v-4129b6d2]{background:linear-gradient(135deg,#4cd964,#3ac555)}.section .grid-container .grid-item.primary[data-v-4129b6d2]:active{background:linear-gradient(135deg,#3ac555,#2fb548)}.section .grid-container .grid-item.warning[data-v-4129b6d2]{background:linear-gradient(135deg,#ff9500,#ff8000)}.section .grid-container .grid-item.warning[data-v-4129b6d2]:active{background:linear-gradient(135deg,#ff8000,#e67300)}.section .grid-container .grid-item[data-v-4129b6d2]:active{transform:scale(.98)}

ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/offline/check-order.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/bad-in.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/bad-out-order.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/bad-out.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/location-order-list.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/location-order.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/location-select.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/order-query-list.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/order-query.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/speedy-check.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/index/wms/task-detail.css


ファイルの差分が大きいため隠しています
+ 0 - 0
unpackage/dist/build/app-plus/pages/login/login.css


ファイルの差分が大きいため隠しています
+ 1 - 1
unpackage/dist/dev/app-plus/app-config-service.js


+ 268 - 70
unpackage/dist/dev/app-plus/app-service.js

@@ -4609,7 +4609,7 @@ if (uni.restoreGlobal) {
           mask: true,
           title: "登录中..."
         });
-        uni.$u.http.post("/actuator/debug/loginNotCode", formData).then((res2) => {
+        uni.$u.http.post("/app/appUser/login", formData).then((res2) => {
           if (res2.code == 200) {
             uni.$u.toast("登录成功");
             uni.switchTab({
@@ -4777,6 +4777,16 @@ if (uni.restoreGlobal) {
     __name: "index",
     setup(__props, { expose: __expose }) {
       __expose();
+      function getMenuList() {
+        uni.$u.http.get("/app/appUser/getRouters").then((res2) => {
+          if (res2.code == 200) {
+            uni.setStorageSync("menuList", res2.data);
+          }
+        });
+      }
+      onLoad(() => {
+        getMenuList();
+      });
       const expressOperations = vue.ref([
         {
           name: "中转\n\r签收",
@@ -4932,7 +4942,9 @@ if (uni.restoreGlobal) {
           }
         });
       };
-      const __returned__ = { expressOperations, auditOperations, wmsOperations, statisticsOperations, offlineOperations, entryOperations, handleNavigation, ref: vue.ref };
+      const __returned__ = { getMenuList, expressOperations, auditOperations, wmsOperations, statisticsOperations, offlineOperations, entryOperations, handleNavigation, ref: vue.ref, get onLoad() {
+        return onLoad;
+      } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
     }
@@ -10832,7 +10844,7 @@ This will fail in production.`);
     );
   }
   const __easycom_0$7 = /* @__PURE__ */ _export_sfc(_sfc_main$1D, [["render", _sfc_render$1C], ["__scopeId", "data-v-c8491d64"], ["__file", "E:/书嗨项目/shuhi-app-fornt/uni_modules/uview-plus/components/u-upload/u-upload.vue"]]);
-  const baseUrl = "http://bk.shuhi.com";
+  const baseUrl = "https://bpi.shuhi.com";
   function initRequest() {
     formatAppLog("log", "at config/request.js:9", "初始化了 http 请求代码");
     uni.$u.http.setConfig((config2) => {
@@ -10900,9 +10912,13 @@ This will fail in production.`);
       isUpdate: {
         type: Boolean,
         default: false
+      },
+      loading: {
+        type: Boolean,
+        default: false
       }
     },
-    emits: ["update:filename", "update:keyValue", "success"],
+    emits: ["update:filename", "update:keyValue", "success", "update:loading"],
     setup(__props, { expose: __expose, emit: __emit }) {
       __expose();
       const emit2 = __emit;
@@ -10933,8 +10949,9 @@ This will fail in production.`);
           status: "uploading",
           message: "上传中..."
         });
+        emit2("update:loading", true);
         const result = await uploadFilePromise(file.url);
-        formatAppLog("log", "at components/cy-upload/index.vue:68", result, "result");
+        formatAppLog("log", "at components/cy-upload/index.vue:73", result, "result");
         fileList.value.forEach((v, index2) => {
           if (index2 == fileList.value.length - 1) {
             v.url = result.url;
@@ -10942,9 +10959,10 @@ This will fail in production.`);
             v.message = "";
           }
         });
-        formatAppLog("log", "at components/cy-upload/index.vue:77", fileList.value, "fileList.value");
+        formatAppLog("log", "at components/cy-upload/index.vue:82", fileList.value, "fileList.value");
         emit2("update:filename", fileList.value.map((v) => v.url));
         emit2("success", result);
+        emit2("update:loading", false);
       };
       const deletePic = (event) => {
         fileList.value.splice(event.index, 1);
@@ -11011,6 +11029,7 @@ This will fail in production.`);
       const emit2 = __emit;
       const formRef = vue.ref(null);
       const submitting = vue.ref(false);
+      const loading = vue.ref(false);
       const formData = vue.reactive({
         feedbackContent: "",
         imgUrl: [],
@@ -11064,7 +11083,7 @@ This will fail in production.`);
       __expose({
         open: open2
       });
-      const __returned__ = { show, emit: emit2, formRef, submitting, formData, rules: rules2, open: open2, handleCancel, handleConfirm, resetForm, cyUpload, ref: vue.ref, reactive: vue.reactive };
+      const __returned__ = { show, emit: emit2, formRef, submitting, loading, formData, rules: rules2, open: open2, handleCancel, handleConfirm, resetForm, cyUpload, ref: vue.ref, reactive: vue.reactive };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
     }
@@ -11122,7 +11141,8 @@ This will fail in production.`);
                     filename: $setup.formData.imgUrl,
                     "onUpdate:filename": _cache[1] || (_cache[1] = ($event) => $setup.formData.imgUrl = $event),
                     multiple: "",
-                    maxCount: 4
+                    maxCount: 4,
+                    loading: $setup.loading
                   }, {
                     default: vue.withCtx(() => [
                       vue.createElementVNode("view", { class: "upload-slot" }, [
@@ -11135,7 +11155,7 @@ This will fail in production.`);
                     ]),
                     _: 1
                     /* STABLE */
-                  }, 8, ["filename"])
+                  }, 8, ["filename", "loading"])
                 ]),
                 _: 1
                 /* STABLE */
@@ -11157,8 +11177,9 @@ This will fail in production.`);
               type: "primary",
               text: "确认",
               onClick: $setup.handleConfirm,
-              loading: $setup.submitting
-            }, null, 8, ["loading"])
+              loading: $setup.submitting,
+              disabled: $setup.loading
+            }, null, 8, ["loading", "disabled"])
           ])
         ])
       ]),
@@ -11173,7 +11194,7 @@ This will fail in production.`);
       __expose();
       const showFeedback = vue.ref(null);
       function handleFeedbackSubmit(data) {
-        formatAppLog("log", "at pages/book/index.vue:47", "反馈数据:", data);
+        formatAppLog("log", "at pages/book/index.vue:48", "反馈数据:", data);
       }
       const searchText = vue.ref("");
       const bookList = vue.ref([]);
@@ -11225,8 +11246,13 @@ This will fail in production.`);
           getSimpleBookInfoByIsbn(e.barcode);
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { showFeedback, handleFeedbackSubmit, searchText, bookList, handleSearch, getSimpleBookInfoByIsbn, scanCode, editBook, ref: vue.ref, computed: vue.computed, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, FeedbackPopup };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -11782,8 +11808,13 @@ This will fail in production.`);
           handleBarcode(e.barcode);
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { placeholderStyle: placeholderStyle$2, customStyle, selectedWarehouse, form, showSelector, openWarehouseSelector, handleWarehouseSelected, scanCode, handleBarcode, getUserBindWarehouse, reactive: vue.reactive, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, WarehouseSelector };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -12650,8 +12681,13 @@ This will fail in production.`);
           handleSubmitBatch();
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { selectedBatchId, showBatchSelector, count, formData, batchList, getBatchList, openBatchSelector, selectBatch, handleSearch, handleSubmitBatch, handleScan, createNewBatch, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -12908,10 +12944,10 @@ This will fail in production.`);
           success: (res2) => {
             unpackCode.value = res2.result;
             confirmTrackingNumber(res2.result);
-            formatAppLog("log", "at pages/index/express/quick-unpack.vue:66", "扫码结果:", res2.result);
+            formatAppLog("log", "at pages/index/express/quick-unpack.vue:67", "扫码结果:", res2.result);
           },
           fail: (err) => {
-            formatAppLog("error", "at pages/index/express/quick-unpack.vue:69", "扫码失败:", err);
+            formatAppLog("error", "at pages/index/express/quick-unpack.vue:70", "扫码失败:", err);
           }
         });
       }
@@ -12935,10 +12971,15 @@ This will fail in production.`);
       onUnload(() => {
         plus.key.removeEventListener("keyup", keypress);
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { goScan, unpackCode, confirmTrackingNumber, scanCode, inputCache, keypress, ref: vue.ref, get onLoad() {
         return onLoad;
       }, get onUnload() {
         return onUnload;
+      }, get onShow() {
+        return onShow;
       }, get keymap() {
         return keymap;
       } };
@@ -14318,12 +14359,17 @@ This will fail in production.`);
           handleSearch();
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { tabList, curNow, exceptionList, get urlList() {
         return urlList;
       }, set urlList(v) {
         urlList = v;
       }, requestStr, sectionChange, pageScrollRef, otherParams, updateList, handleSearch, handleScan, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, ExceptionItem, PageScroll: pageScroll };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -14461,8 +14507,13 @@ This will fail in production.`);
           handleBarcode(e.barcode);
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { placeholderStyle: placeholderStyle$1, customStyle, selectedWarehouse, form, showSelector, openWarehouseSelector, handleWarehouseSelected, scanCode, handleBarcode, getUserBindWarehouse, reactive: vue.reactive, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, WarehouseSelector };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -14586,8 +14637,13 @@ This will fail in production.`);
           form.value.packageCode = e.barcode;
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { placeholderStyle, customStyle, formRef, form, rules: rules2, scanCode, submitForm, ref: vue.ref, reactive: vue.reactive, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, cyUpload };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -14726,8 +14782,13 @@ This will fail in production.`);
           handleSubmit();
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { formData, handleSubmit, handleScan, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -15503,8 +15564,13 @@ This will fail in production.`);
           addOrUpdateIsbn(e.barcode);
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { isbnList, showModal, newIsbn, removeItem, goBack, clearAll, addOrUpdateIsbn, handleIsbn, handleScan, isValidISBN, handleQuery, addIsbn, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -15948,7 +16014,7 @@ This will fail in production.`);
         search: ""
       });
       const handleSearch = () => {
-        formatAppLog("log", "at pages/index/audit/express-order.vue:46", "查询:", form.value.search);
+        formatAppLog("log", "at pages/index/audit/express-order.vue:47", "查询:", form.value.search);
         uni.$u.http.get("/app/orderinfo/getOrderInfoForCheck", {
           params: {
             ...form.value
@@ -15979,8 +16045,13 @@ This will fail in production.`);
           handleSearch();
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { form, handleSearch, handleScan, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -17706,8 +17777,8 @@ This will fail in production.`);
         }, 0);
       });
       function handleBookClick(book) {
-        if (props2.detail.status == 10) {
-          uni.$u.ttsModule.speak("订单已审核");
+        if (props2.detail.status >= 10) {
+          uni.$u.ttsModule.speak("订单已审核完成");
           return;
         }
         uni.navigateTo({
@@ -18430,8 +18501,8 @@ This will fail in production.`);
           uni.$u.ttsModule.speak(text);
           return;
         }
-        if (orderDetail.value.status == 10) {
-          uni.$u.ttsModule.speak("订单已审核");
+        if (orderDetail.value.status >= 10) {
+          uni.$u.ttsModule.speak("订单已审核完成");
           return;
         }
         let isbns = orderDetail.value.detailVoList.map((item) => item.isbn);
@@ -18478,6 +18549,7 @@ This will fail in production.`);
         });
       });
       onShow(() => {
+        uni.$u.updateActivePageOnShow();
         getOrderDetail();
       });
       const __returned__ = { showAuditorSelector, selectedAuditor, handleAuditorSelected, toView, scrollToView, scrollToTop, handleBindCode, list, current, handleSectionChange, allLetters, onGetAllFirstLetter, handleLogisticsConfirm, handleConfirm, handleComplete, orderDetail, getOrderDetail, checkIsbn, handleScan, handleScanCode, orderId, isOnLoad, type: type2, ref: vue.ref, get onLoad() {
@@ -18989,6 +19061,7 @@ This will fail in production.`);
           checkUserId.value = (_a = uni.getStorageSync("userInfo")) == null ? void 0 : _a.userId;
           orderDetail.value = uni.getStorageSync("orderDetail");
         }
+        uni.$u.updateActivePageOnShow();
       });
       const __returned__ = { detail, getBookInfo, auditBook, getBookInfoAndAuditInfo, list, current, handleSectionChange, auditData, handleAuditSelected, scannedBooks, checkIsbn, handleScan, handleScanCode, auditInfoRef, handleAudit, checkUserId, orderId, orderDetail, get isbnScan() {
         return isbnScan;
@@ -19335,10 +19408,6 @@ This will fail in production.`);
                 let text = `请注意${isbn}需要取出`;
                 uni.$u.ttsModule.speak(text);
               }
-              if (scannedNum >= notAuditNum && scannedNum < notAuditNum + poorNum) {
-                let text = `${isbn}已审核为极差`;
-                uni.$u.ttsModule.speak(text);
-              }
               scannedBooks.value.push(isbn);
               getBookInfo(isbn);
             }
@@ -19379,7 +19448,7 @@ This will fail in production.`);
         if (checkUserInfo.userId) {
           checkUserId.value = checkUserInfo.userId;
         }
-        uni.$u.http.post("/app/orderinfo/checkOrder", {
+        uni.$u.http.post("/app/orderinfo/checkOrderBatch", {
           checkUserId: checkUserId.value,
           orderId: orderId.value,
           checkList: scannedBooks.value.map((isbn) => ({ sts: 1, com: "", isbn }))
@@ -19408,6 +19477,7 @@ This will fail in production.`);
       });
       onShow(() => {
         var _a;
+        uni.$u.updateActivePageOnShow();
         checkUserId.value = (_a = uni.getStorageSync("userInfo")) == null ? void 0 : _a.userId;
         orderDetail.value = uni.getStorageSync("orderDetail");
       });
@@ -25513,6 +25583,9 @@ This will fail in production.`);
           formData.godownId = data.id;
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       vue.onUnmounted(() => {
         uni.$off("updateLocation");
         uni.$off("updateWarehouse");
@@ -25534,7 +25607,9 @@ This will fail in production.`);
           url: "/pages/index/wms/warehouse-select?godownId=" + formData.godownId
         });
       };
-      const __returned__ = { waybillCode, formData, ordersMap, codeMap, getDetailByCode: getDetailByCode2, remarkVisible, currentRemark, currentEditIndex, goBack, onSubmit, handleSubmitConfirm, clearData, editOrder, openScan, selectLocation, deleteOrder, openRemarkDialog, handleRemarkConfirm, selectWarehouse, ref: vue.ref, reactive: vue.reactive, onMounted: vue.onMounted, onUnmounted: vue.onUnmounted, BadItem, get VolumeTTS() {
+      const __returned__ = { waybillCode, formData, ordersMap, codeMap, getDetailByCode: getDetailByCode2, remarkVisible, currentRemark, currentEditIndex, goBack, onSubmit, handleSubmitConfirm, clearData, editOrder, openScan, selectLocation, deleteOrder, openRemarkDialog, handleRemarkConfirm, selectWarehouse, ref: vue.ref, reactive: vue.reactive, onMounted: vue.onMounted, onUnmounted: vue.onUnmounted, get onShow() {
+        return onShow;
+      }, BadItem, get VolumeTTS() {
         return VolumeTTS;
       }, RemarkDialog };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
@@ -25715,9 +25790,10 @@ This will fail in production.`);
     setup(__props, { expose: __expose }) {
       __expose();
       const searchText = vue.ref("");
+      const searchType = vue.ref("1");
       const onSearch = () => {
         uni.navigateTo({
-          url: `/pages/index/wms/bad-out-order?searchText=${searchText.value}`
+          url: `/pages/index/wms/bad-out-order?searchText=${searchText.value}&searchType=${searchType.value}`
         });
       };
       const openScan = () => {
@@ -25734,12 +25810,14 @@ This will fail in production.`);
           }
         });
       };
-      const __returned__ = { searchText, onSearch, openScan, ref: vue.ref, computed: vue.computed, onMounted: vue.onMounted };
+      const __returned__ = { searchText, searchType, onSearch, openScan, ref: vue.ref, computed: vue.computed, onMounted: vue.onMounted };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
     }
   };
   function _sfc_render$E(_ctx, _cache, $props, $setup, $data, $options) {
+    const _component_u_radio = resolveEasycom(vue.resolveDynamicComponent("u-radio"), __easycom_0$6);
+    const _component_u_radio_group = resolveEasycom(vue.resolveDynamicComponent("u-radio-group"), __easycom_1$5);
     const _component_u_search = resolveEasycom(vue.resolveDynamicComponent("u-search"), __easycom_4$2);
     const _component_u_icon = resolveEasycom(vue.resolveDynamicComponent("u-icon"), __easycom_0$g);
     return vue.openBlock(), vue.createElementBlock("view", { class: "container flex-d h100" }, [
@@ -25749,25 +25827,47 @@ This will fail in production.`);
       ]),
       vue.createCommentVNode(" 底部搜索框 "),
       vue.createElementVNode("view", {
-        class: "pad-20 flex-a",
+        class: "pad-20 flex flex-column",
         style: { "background": "#ffffff" }
       }, [
-        vue.createVNode(_component_u_search, {
-          modelValue: $setup.searchText,
-          "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $setup.searchText = $event),
-          placeholder: "请输入快递单号/订单编号",
-          "show-action": false,
-          clearabled: true,
-          onChange: $setup.onSearch,
-          height: "40",
-          onClick: _cache[1] || (_cache[1] = ($event) => $setup.searchText = "")
-        }, null, 8, ["modelValue"]),
-        vue.createVNode(_component_u_icon, {
-          name: "scan",
-          size: "28",
-          color: "#19be6b",
-          onClick: $setup.openScan
-        })
+        vue.createVNode(_component_u_radio_group, {
+          modelValue: $setup.searchType,
+          "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $setup.searchType = $event),
+          class: "mb-20 ml-20"
+        }, {
+          default: vue.withCtx(() => [
+            vue.createVNode(_component_u_radio, {
+              label: "查订单",
+              name: "1",
+              "label-size": "17"
+            }),
+            vue.createVNode(_component_u_radio, {
+              label: "查物流",
+              "custom-style": "margin-left:20px",
+              name: "2",
+              "label-size": "17"
+            })
+          ]),
+          _: 1
+          /* STABLE */
+        }, 8, ["modelValue"]),
+        vue.createElementVNode("view", { class: "flex-a" }, [
+          vue.createVNode(_component_u_search, {
+            modelValue: $setup.searchText,
+            "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => $setup.searchText = $event),
+            placeholder: "请输入快递单号/订单编号",
+            "show-action": false,
+            clearabled: true,
+            onSearch: $setup.onSearch,
+            height: "40"
+          }, null, 8, ["modelValue"]),
+          vue.createVNode(_component_u_icon, {
+            name: "scan",
+            size: "28",
+            color: "#19be6b",
+            onClick: $setup.openScan
+          })
+        ])
       ])
     ]);
   }
@@ -25883,6 +25983,7 @@ This will fail in production.`);
     setup(__props, { expose: __expose }) {
       __expose();
       const searchText = vue.ref("");
+      const searchType = vue.ref("1");
       const errorMsg = vue.ref("");
       const hasData = vue.ref(false);
       const locationInfo = vue.ref({
@@ -25890,10 +25991,12 @@ This will fail in production.`);
         waybillCode: "",
         orderId: "",
         badNum: "",
-        remark: ""
+        remark: "",
+        refundWaybillCode: ""
       });
       const badList = vue.ref([]);
       onLoad((options) => {
+        searchType.value = options.searchType || "1";
         if (options.searchText) {
           searchText.value = options.searchText;
           onSearch();
@@ -25909,10 +26012,9 @@ This will fail in production.`);
           return;
         }
         try {
-          const searchType = getSearchType(searchText.value);
           const res2 = await uni.$u.http.post("/app/stock/findOrderOutStock", {
             search: searchText.value,
-            searchType
+            searchType: searchType.value
           });
           if (res2.code == 200) {
             const data = res2.data;
@@ -25923,7 +26025,8 @@ This will fail in production.`);
               waybillCode: data.waybillCode || "",
               orderId: data.orderId || "",
               badNum: data.badNum || "",
-              remark: data.remark || ""
+              remark: data.remark || "",
+              refundWaybillCode: data.refundWaybillCode || ""
             };
             badList.value = data.detailVoList || [];
           } else {
@@ -26007,7 +26110,7 @@ This will fail in production.`);
         currentEditIndex.value = -1;
         currentRemark.value = "";
       };
-      const __returned__ = { searchText, errorMsg, hasData, locationInfo, badList, getSearchType, onSearch, openScan, onConfirm, remarkVisible, currentRemark, currentEditIndex, openRemarkDialog, handleRemarkConfirm, ref: vue.ref, onMounted: vue.onMounted, BadOutCard, RemarkDialog, get VolumeTTS() {
+      const __returned__ = { searchText, searchType, errorMsg, hasData, locationInfo, badList, getSearchType, onSearch, openScan, onConfirm, remarkVisible, currentRemark, currentEditIndex, openRemarkDialog, handleRemarkConfirm, ref: vue.ref, onMounted: vue.onMounted, BadOutCard, RemarkDialog, get VolumeTTS() {
         return VolumeTTS;
       }, get onLoad() {
         return onLoad;
@@ -26029,12 +26132,12 @@ This will fail in production.`);
             vue.createVNode(_component_u_search, {
               modelValue: $setup.searchText,
               "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => $setup.searchText = $event),
-              placeholder: "请输入运单号/订单编号",
+              placeholder: $setup.searchType == "1" ? "请输入订单编号" : "请输入运单号",
               "show-action": false,
               clearabled: true,
-              onChange: $setup.onSearch,
+              onSearch: $setup.onSearch,
               height: "40"
-            }, null, 8, ["modelValue"]),
+            }, null, 8, ["modelValue", "placeholder"]),
             vue.createVNode(_component_u_icon, {
               name: "scan",
               size: "28",
@@ -26085,6 +26188,13 @@ This will fail in production.`);
                 1
                 /* TEXT */
               ),
+              vue.createElementVNode(
+                "view",
+                { class: "info-item" },
+                "退回物流:" + vue.toDisplayString($setup.locationInfo.refundWaybillCode || "-"),
+                1
+                /* TEXT */
+              ),
               vue.createElementVNode(
                 "view",
                 { class: "info-item" },
@@ -26375,8 +26485,13 @@ This will fail in production.`);
           }
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { query, orderQuery, openScan, reactive: vue.reactive, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -26917,8 +27032,13 @@ This will fail in production.`);
           }
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { list1, activeTab, query, determineSearchType, detail, orderQuery, operationLogs, getOperationLogs, handleTabChange, openScan, reactive: vue.reactive, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, BookInfo };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -27079,8 +27199,13 @@ This will fail in production.`);
           }
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { positionCode, onSearch, openScan, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -27297,8 +27422,13 @@ This will fail in production.`);
           }
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { orderCode, originList, orderList, detail, getOrderListByPositionCode, onSearch, openScan, reactive: vue.reactive, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, LocationOrderItem };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -27423,8 +27553,13 @@ This will fail in production.`);
           }
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { searchText, locations, getLocationListByGodownId, scrollHeight, onSearch, openScan, selectLocation, godownId, positionCode, ref: vue.ref, computed: vue.computed, onMounted: vue.onMounted, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -27728,6 +27863,9 @@ This will fail in production.`);
           }
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       onUnload(() => {
         uni.$off("selectedProducts");
       });
@@ -27735,6 +27873,8 @@ This will fail in production.`);
         return onLoad;
       }, get onUnload() {
         return onUnload;
+      }, get onShow() {
+        return onShow;
       }, LocationOrderItem };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -28081,8 +28221,13 @@ This will fail in production.`);
           handleBarcode(e.barcode);
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { bookList, totalBooks, totalPrice, removeBook, handleSubmit, handleScan, handleBarcode, ref: vue.ref, computed: vue.computed, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       }, BookItem };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -28446,8 +28591,13 @@ This will fail in production.`);
           loadBookInfo(e.barcode);
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { searchValue, scannedISBN, currentTab, tabsList, bookInfo, handleSearch, handleScan, loadBookInfo, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -28762,8 +28912,13 @@ This will fail in production.`);
           form.value.isbn = e.barcode;
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { customStyle, labelStyle, placeholderStyle: placeholderStyle2, form, rules: rules2, handleScan, formRef, submitForm, ref: vue.ref, get onLoad() {
         return onLoad;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -29318,6 +29473,9 @@ This will fail in production.`);
           }
         });
       });
+      onShow(() => {
+        uni.$u.updateActivePageOnShow();
+      });
       const __returned__ = { currentTask, totalTasks, curTaskInfo, nextLocation, orderList, ttsModule: ttsModule2, taskCode, searchText, badList, handleNextTask, onSearch, confirmStockTask, unlockTask, onSubmit, goBack, get isFirstScan() {
         return isFirstScan;
       }, set isFirstScan(v) {
@@ -29328,6 +29486,8 @@ This will fail in production.`);
         return onLoad;
       }, get onUnload() {
         return onUnload;
+      }, get onShow() {
+        return onShow;
       } };
       Object.defineProperty(__returned__, "__isScriptSetup", { enumerable: false, value: true });
       return __returned__;
@@ -31081,20 +31241,64 @@ This will fail in production.`);
       formatAppLog("log", "at utils/useBarcodeModule.js:9", "初始化扫描", ret);
     });
   }
+  const callbackRegistry = {
+    activePagePath: null,
+    callbacks: /* @__PURE__ */ new Map()
+    // 使用Map存储每个页面路径对应的回调函数
+  };
+  const globalEventHandler = function(e) {
+    if (!callbackRegistry.activePagePath)
+      return;
+    const callback = callbackRegistry.callbacks.get(callbackRegistry.activePagePath);
+    if (callback) {
+      callback(e);
+    }
+  };
+  let isGlobalListenerInitialized = false;
+  function initGlobalListener() {
+    if (isGlobalListenerInitialized)
+      return;
+    const globalEvent = requireNativePlugin("globalEvent");
+    globalEvent.removeEventListener("iDataBarcodeEvent", globalEventHandler);
+    globalEvent.addEventListener("iDataBarcodeEvent", globalEventHandler);
+    isGlobalListenerInitialized = true;
+  }
   function useGlobalEvent(onChange) {
-    var globalEvent = requireNativePlugin("globalEvent");
-    const handler = function(e) {
-      onChange && onChange(e);
-    };
-    globalEvent.removeEventListener("iDataBarcodeEvent", handler);
-    globalEvent.addEventListener("iDataBarcodeEvent", handler);
+    initGlobalListener();
+    const pages2 = getCurrentPages();
+    const currentPage = pages2[pages2.length - 1];
+    const pagePath = currentPage ? currentPage.route : null;
+    if (!pagePath) {
+      formatAppLog("error", "at utils/useBarcodeModule.js:62", "无法获取当前页面路径");
+      return () => {
+      };
+    }
+    callbackRegistry.activePagePath = pagePath;
+    callbackRegistry.callbacks.set(pagePath, onChange);
+    formatAppLog("log", "at utils/useBarcodeModule.js:72", `页面 ${pagePath} 已注册扫描回调`);
     return () => {
-      globalEvent.removeEventListener("iDataBarcodeEvent", handler);
+      callbackRegistry.callbacks.delete(pagePath);
+      formatAppLog("log", "at utils/useBarcodeModule.js:77", `页面 ${pagePath} 的扫描回调已移除`);
     };
   }
+  function updateActivePageOnShow() {
+    const pages2 = getCurrentPages();
+    const currentPage = pages2[pages2.length - 1];
+    const pagePath = currentPage ? currentPage.route : null;
+    if (!pagePath) {
+      formatAppLog("error", "at utils/useBarcodeModule.js:91", "无法获取当前页面路径");
+      return;
+    }
+    callbackRegistry.activePagePath = pagePath;
+    formatAppLog("log", "at utils/useBarcodeModule.js:97", `当前活跃页面已更新为: ${pagePath}`);
+  }
   function useGlobalEventRemove() {
-    var globalEvent = requireNativePlugin("globalEvent");
-    globalEvent.removeEventListener("iDataBarcodeEvent");
+    const globalEvent = requireNativePlugin("globalEvent");
+    globalEvent.removeEventListener("iDataBarcodeEvent", globalEventHandler);
+    isGlobalListenerInitialized = false;
+    callbackRegistry.callbacks.clear();
+    callbackRegistry.activePagePath = null;
+    formatAppLog("log", "at utils/useBarcodeModule.js:110", "全局扫描监听器已完全移除");
   }
   function useRouteMonitor(onChange) {
     uni.addInterceptor("navigateTo", {
@@ -33378,7 +33582,6 @@ This will fail in production.`);
       __expose();
       let touchHandler;
       onLaunch(() => {
-        formatAppLog("log", "at App.vue:12", "App Launch");
         if (!store.token) {
           let token = uni.getStorageSync("token");
           if (token) {
@@ -33392,7 +33595,6 @@ This will fail in production.`);
           }
         }
         touchHandler = (e) => {
-          formatAppLog("log", "at App.vue:29", "touchHandler", e);
           playClickSound();
         };
         var globalEvent = requireNativePlugin("globalEvent");
@@ -33400,13 +33602,6 @@ This will fail in production.`);
         useInit();
       });
       onShow(() => {
-        useRouteMonitor((url2, from) => {
-          formatAppLog("log", "at App.vue:50", "onShow", url2, from);
-          useGlobalEventRemove();
-        });
-      });
-      onHide(() => {
-        formatAppLog("log", "at App.vue:60", "App Hide");
       });
       onUnload(() => {
         if (touchHandler) {
@@ -33433,6 +33628,8 @@ This will fail in production.`);
         return useGlobalEventRemove;
       }, get useInit() {
         return useInit;
+      }, get updateActivePageOnShow() {
+        return updateActivePageOnShow;
       }, get useRouteMonitor() {
         return useRouteMonitor;
       }, get playClickSound() {
@@ -35053,6 +35250,7 @@ This will fail in production.`);
   useInit();
   uni.$u.ttsModule = ttsModule;
   uni.$u.useGlobalEvent = useGlobalEvent;
+  uni.$u.updateActivePageOnShow = updateActivePageOnShow;
   function createApp() {
     const app = vue.createVueApp(App);
     initRequest();

+ 2 - 1
unpackage/dist/dev/app-plus/manifest.json

@@ -5,7 +5,7 @@
     "iPad"
   ],
   "id": "__UNI__65C1C73",
-  "name": "PDS",
+  "name": "书嗨",
   "version": {
     "name": "1.0.1",
     "code": 101
@@ -21,6 +21,7 @@
     "Barcode": {},
     "Bluetooth": {},
     "Webview-x5": {},
+    "Camera": {},
     "UniNView": {
       "description": "UniNView原生渲染"
     }

+ 6 - 3
unpackage/dist/dev/app-plus/pages/index/index.css

@@ -32,6 +32,7 @@
   background: #ffffff;
   border-radius: 0.5rem;
   padding: 0.625rem;
+  padding-right: 0;
   box-shadow: 0 0.0625rem 0.375rem rgba(0, 0, 0, 0.05);
 }
 .section .section-title[data-v-1cf27b2a] {
@@ -46,11 +47,10 @@
 .section .grid-container[data-v-1cf27b2a] {
   display: flex;
   flex-wrap: wrap;
-  gap: 0.625rem;
   padding: 0.3125rem;
 }
 .section .grid-container .grid-item[data-v-1cf27b2a] {
-  flex: 0 0 calc(50% - 0.3125rem);
+  width: calc(50% - 0.625rem);
   min-height: 4.625rem;
   display: flex;
   align-items: center;
@@ -64,9 +64,12 @@
   transition: all 0.3s;
   white-space: pre-wrap;
   box-sizing: border-box;
+  margin-right: 0.625rem;
+  margin-bottom: 0.625rem;
 }
 .section .grid-container .grid-item[style*="grid-column: span 2"][data-v-1cf27b2a] {
-  flex: 0 0 100%;
+  width: calc(100% - 0.625rem);
+  margin-right: 0.625rem;
 }
 .section .grid-container .grid-item.primary[data-v-1cf27b2a] {
   background: linear-gradient(135deg, #4cd964, #3ac555);

+ 145 - 0
unpackage/dist/dev/app-plus/pages/index/wms/bad-out.css

@@ -112,6 +112,151 @@ uni-view[data-v-ac70166d], uni-scroll-view[data-v-ac70166d], uni-swiper-item[dat
 /* 垂直间距 */
 /* 透明度 */
 /* 文章场景相关 */
+uni-view[data-v-83036558], uni-scroll-view[data-v-83036558], uni-swiper-item[data-v-83036558] {
+  display: flex;
+  flex-direction: column;
+  flex-shrink: 0;
+  flex-grow: 0;
+  flex-basis: auto;
+  align-items: stretch;
+  align-content: flex-start;
+}
+.u-radio[data-v-83036558] {
+
+  display: flex;
+
+  flex-direction: row;
+  overflow: hidden;
+  flex-direction: row;
+  align-items: center;
+  margin-bottom: 5px;
+  margin-top: 5px;
+}
+.u-radio-label--left[data-v-83036558] {
+  flex-direction: row;
+}
+.u-radio-label--right[data-v-83036558] {
+  flex-direction: row-reverse;
+  justify-content: space-between;
+}
+.u-radio__icon-wrap[data-v-83036558] {
+  box-sizing: border-box;
+  transition-property: border-color, background-color, color;
+  transition-duration: 0.2s;
+  color: #606266;
+
+  display: flex;
+
+  flex-direction: row;
+  align-items: center;
+  justify-content: center;
+  color: transparent;
+  text-align: center;
+  margin-right: 6px;
+  font-size: 20px;
+  border-width: 1px;
+  border-color: #c8c9cc;
+  border-style: solid;
+}
+.u-radio__icon-wrap--circle[data-v-83036558] {
+  border-radius: 100%;
+}
+.u-radio__icon-wrap--square[data-v-83036558] {
+  border-radius: 3px;
+}
+.u-radio__icon-wrap--checked[data-v-83036558] {
+  color: #fff;
+  background-color: red;
+  border-color: #2979ff;
+}
+.u-radio__icon-wrap--disabled[data-v-83036558] {
+  background-color: #ebedf0 !important;
+}
+.u-radio__icon-wrap--disabled--checked[data-v-83036558] {
+  color: #c8c9cc !important;
+}
+.u-radio__label[data-v-83036558] {
+  word-wrap: break-word;
+  margin-left: 5px;
+  margin-right: 12px;
+  color: #606266;
+  font-size: 15px;
+}
+.u-radio__label--disabled[data-v-83036558] {
+  color: #c8c9cc;
+}
+/**
+ * 这里是uni-app内置的常用样式变量
+ *
+ * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
+ * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
+ *
+ */
+/**
+ * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
+ *
+ * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
+ */
+/* 颜色变量 */
+/* 行为相关颜色 */
+/* 文字基本颜色 */
+/* 背景颜色 */
+/* 边框颜色 */
+/* 尺寸变量 */
+/* 文字尺寸 */
+/* 图片尺寸 */
+/* Border Radius */
+/* 水平间距 */
+/* 垂直间距 */
+/* 透明度 */
+/* 文章场景相关 */
+uni-view[data-v-cbc8bf70], uni-scroll-view[data-v-cbc8bf70], uni-swiper-item[data-v-cbc8bf70] {
+  display: flex;
+  flex-direction: column;
+  flex-shrink: 0;
+  flex-grow: 0;
+  flex-basis: auto;
+  align-items: stretch;
+  align-content: flex-start;
+}
+.u-radio-group[data-v-cbc8bf70] {
+  flex: 1;
+}
+.u-radio-group--row[data-v-cbc8bf70] {
+  display: flex;
+  flex-flow: row wrap;
+}
+.u-radio-group--column[data-v-cbc8bf70] {
+
+  display: flex;
+
+  flex-direction: column;
+}
+/**
+ * 这里是uni-app内置的常用样式变量
+ *
+ * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
+ * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
+ *
+ */
+/**
+ * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
+ *
+ * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
+ */
+/* 颜色变量 */
+/* 行为相关颜色 */
+/* 文字基本颜色 */
+/* 背景颜色 */
+/* 边框颜色 */
+/* 尺寸变量 */
+/* 文字尺寸 */
+/* 图片尺寸 */
+/* Border Radius */
+/* 水平间距 */
+/* 垂直间距 */
+/* 透明度 */
+/* 文章场景相关 */
 uni-view[data-v-e082a34a], uni-scroll-view[data-v-e082a34a], uni-swiper-item[data-v-e082a34a] {
   display: flex;
   flex-direction: column;

+ 0 - 171
unpackage/dist/dev/mp-weixin/app.js

@@ -1,171 +0,0 @@
-"use strict";
-Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
-const common_vendor = require("./common/vendor.js");
-const store_index = require("./store/index.js");
-const uni_modules_uviewPlus_index = require("./uni_modules/uview-plus/index.js");
-const config_share = require("./config/share.js");
-const config_request = require("./config/request.js");
-require("./store/uses.js");
-require("./uni_modules/uview-plus/libs/mixin/mixin.js");
-require("./uni_modules/uview-plus/libs/mixin/mpMixin.js");
-require("./uni_modules/uview-plus/libs/luch-request/core/Request.js");
-require("./uni_modules/uview-plus/libs/luch-request/core/dispatchRequest.js");
-require("./uni_modules/uview-plus/libs/luch-request/adapters/index.js");
-require("./uni_modules/uview-plus/libs/luch-request/helpers/buildURL.js");
-require("./uni_modules/uview-plus/libs/luch-request/utils.js");
-require("./uni_modules/uview-plus/libs/luch-request/core/buildFullPath.js");
-require("./uni_modules/uview-plus/libs/luch-request/helpers/isAbsoluteURL.js");
-require("./uni_modules/uview-plus/libs/luch-request/helpers/combineURLs.js");
-require("./uni_modules/uview-plus/libs/luch-request/core/settle.js");
-require("./uni_modules/uview-plus/libs/luch-request/core/InterceptorManager.js");
-require("./uni_modules/uview-plus/libs/luch-request/core/mergeConfig.js");
-require("./uni_modules/uview-plus/libs/luch-request/core/defaults.js");
-require("./uni_modules/uview-plus/libs/luch-request/utils/clone.js");
-require("./uni_modules/uview-plus/libs/util/route.js");
-require("./uni_modules/uview-plus/libs/function/colorGradient.js");
-require("./uni_modules/uview-plus/libs/function/test.js");
-require("./uni_modules/uview-plus/libs/function/debounce.js");
-require("./uni_modules/uview-plus/libs/function/throttle.js");
-require("./uni_modules/uview-plus/libs/function/index.js");
-require("./uni_modules/uview-plus/libs/function/digit.js");
-require("./uni_modules/uview-plus/libs/config/config.js");
-require("./uni_modules/uview-plus/libs/config/props.js");
-require("./uni_modules/uview-plus/libs/config/props/actionSheet.js");
-require("./uni_modules/uview-plus/libs/config/props/album.js");
-require("./uni_modules/uview-plus/libs/config/props/alert.js");
-require("./uni_modules/uview-plus/libs/config/props/avatar.js");
-require("./uni_modules/uview-plus/libs/config/props/avatarGroup.js");
-require("./uni_modules/uview-plus/libs/config/props/backtop.js");
-require("./uni_modules/uview-plus/libs/config/props/badge.js");
-require("./uni_modules/uview-plus/libs/config/props/button.js");
-require("./uni_modules/uview-plus/libs/config/props/calendar.js");
-require("./uni_modules/uview-plus/libs/config/props/carKeyboard.js");
-require("./uni_modules/uview-plus/libs/config/props/cell.js");
-require("./uni_modules/uview-plus/libs/config/props/cellGroup.js");
-require("./uni_modules/uview-plus/libs/config/props/checkbox.js");
-require("./uni_modules/uview-plus/libs/config/props/checkboxGroup.js");
-require("./uni_modules/uview-plus/libs/config/props/circleProgress.js");
-require("./uni_modules/uview-plus/libs/config/props/code.js");
-require("./uni_modules/uview-plus/libs/config/props/codeInput.js");
-require("./uni_modules/uview-plus/libs/config/props/col.js");
-require("./uni_modules/uview-plus/libs/config/props/collapse.js");
-require("./uni_modules/uview-plus/libs/config/props/collapseItem.js");
-require("./uni_modules/uview-plus/libs/config/props/columnNotice.js");
-require("./uni_modules/uview-plus/libs/config/props/countDown.js");
-require("./uni_modules/uview-plus/libs/config/props/countTo.js");
-require("./uni_modules/uview-plus/libs/config/props/datetimePicker.js");
-require("./uni_modules/uview-plus/libs/config/props/divider.js");
-require("./uni_modules/uview-plus/libs/config/props/empty.js");
-require("./uni_modules/uview-plus/libs/config/props/form.js");
-require("./uni_modules/uview-plus/libs/config/props/formItem.js");
-require("./uni_modules/uview-plus/libs/config/props/gap.js");
-require("./uni_modules/uview-plus/libs/config/props/grid.js");
-require("./uni_modules/uview-plus/libs/config/props/gridItem.js");
-require("./uni_modules/uview-plus/libs/config/props/icon.js");
-require("./uni_modules/uview-plus/libs/config/props/image.js");
-require("./uni_modules/uview-plus/libs/config/props/indexAnchor.js");
-require("./uni_modules/uview-plus/libs/config/props/indexList.js");
-require("./uni_modules/uview-plus/libs/config/props/input.js");
-require("./uni_modules/uview-plus/libs/config/props/keyboard.js");
-require("./uni_modules/uview-plus/libs/config/props/line.js");
-require("./uni_modules/uview-plus/libs/config/props/lineProgress.js");
-require("./uni_modules/uview-plus/libs/config/props/link.js");
-require("./uni_modules/uview-plus/libs/config/props/list.js");
-require("./uni_modules/uview-plus/libs/config/props/listItem.js");
-require("./uni_modules/uview-plus/libs/config/props/loadingIcon.js");
-require("./uni_modules/uview-plus/libs/config/props/loadingPage.js");
-require("./uni_modules/uview-plus/libs/config/props/loadmore.js");
-require("./uni_modules/uview-plus/libs/config/props/modal.js");
-require("./uni_modules/uview-plus/libs/config/props/navbar.js");
-require("./uni_modules/uview-plus/libs/config/color.js");
-require("./uni_modules/uview-plus/libs/config/props/noNetwork.js");
-require("./uni_modules/uview-plus/libs/config/props/noticeBar.js");
-require("./uni_modules/uview-plus/libs/config/props/notify.js");
-require("./uni_modules/uview-plus/libs/config/props/numberBox.js");
-require("./uni_modules/uview-plus/libs/config/props/numberKeyboard.js");
-require("./uni_modules/uview-plus/libs/config/props/overlay.js");
-require("./uni_modules/uview-plus/libs/config/props/parse.js");
-require("./uni_modules/uview-plus/libs/config/props/picker.js");
-require("./uni_modules/uview-plus/libs/config/props/popup.js");
-require("./uni_modules/uview-plus/libs/config/props/radio.js");
-require("./uni_modules/uview-plus/libs/config/props/radioGroup.js");
-require("./uni_modules/uview-plus/libs/config/props/rate.js");
-require("./uni_modules/uview-plus/libs/config/props/readMore.js");
-require("./uni_modules/uview-plus/libs/config/props/row.js");
-require("./uni_modules/uview-plus/libs/config/props/rowNotice.js");
-require("./uni_modules/uview-plus/libs/config/props/scrollList.js");
-require("./uni_modules/uview-plus/libs/config/props/search.js");
-require("./uni_modules/uview-plus/libs/config/props/section.js");
-require("./uni_modules/uview-plus/libs/config/props/skeleton.js");
-require("./uni_modules/uview-plus/libs/config/props/slider.js");
-require("./uni_modules/uview-plus/libs/config/props/statusBar.js");
-require("./uni_modules/uview-plus/libs/config/props/steps.js");
-require("./uni_modules/uview-plus/libs/config/props/stepsItem.js");
-require("./uni_modules/uview-plus/libs/config/props/sticky.js");
-require("./uni_modules/uview-plus/libs/config/props/subsection.js");
-require("./uni_modules/uview-plus/libs/config/props/swipeAction.js");
-require("./uni_modules/uview-plus/libs/config/props/swipeActionItem.js");
-require("./uni_modules/uview-plus/libs/config/props/swiper.js");
-require("./uni_modules/uview-plus/libs/config/props/swipterIndicator.js");
-require("./uni_modules/uview-plus/libs/config/props/switch.js");
-require("./uni_modules/uview-plus/libs/config/props/tabbar.js");
-require("./uni_modules/uview-plus/libs/config/props/tabbarItem.js");
-require("./uni_modules/uview-plus/libs/config/props/tabs.js");
-require("./uni_modules/uview-plus/libs/config/props/tag.js");
-require("./uni_modules/uview-plus/libs/config/props/text.js");
-require("./uni_modules/uview-plus/libs/config/props/textarea.js");
-require("./uni_modules/uview-plus/libs/config/props/toast.js");
-require("./uni_modules/uview-plus/libs/config/props/toolbar.js");
-require("./uni_modules/uview-plus/libs/config/props/tooltip.js");
-require("./uni_modules/uview-plus/libs/config/props/transition.js");
-require("./uni_modules/uview-plus/libs/config/props/upload.js");
-require("./uni_modules/uview-plus/libs/config/props/drawer.js");
-require("./uni_modules/uview-plus/libs/config/zIndex.js");
-require("./uni_modules/uview-plus/libs/function/platform.js");
-if (!Math) {
-  "./pages/home/home.js";
-  "./pages/my/my.js";
-}
-const _sfc_main = {
-  __name: "App",
-  setup(__props) {
-    common_vendor.onLaunch(() => {
-      console.log("App Launch");
-      if (!store_index.store.token) {
-        let token = common_vendor.index.getStorageSync("token");
-        if (token) {
-          store_index.store.setToken(token);
-          let userStr = common_vendor.index.getStorageSync("userInfo");
-          if (userStr) {
-            let userInfo = JSON.parse(userStr);
-            if (userInfo.userId) {
-              store_index.store.setUserInfo(userInfo);
-            }
-          }
-        }
-      }
-    });
-    common_vendor.onShow(() => {
-      console.log("App Show");
-    });
-    common_vendor.onHide(() => {
-      console.log("App Hide");
-    });
-    return () => {
-    };
-  }
-};
-const App = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__file", "F:/lty/uniapp-vue3-template/App.vue"]]);
-function createApp() {
-  const app = common_vendor.createSSRApp(App);
-  config_request.initRequest();
-  const pinia = common_vendor.createPinia();
-  app.use(pinia).use(uni_modules_uviewPlus_index.uviewPlus);
-  app.mixin(config_share.share);
-  return {
-    app,
-    pinia
-  };
-}
-createApp().app.mount("#app");
-exports.createApp = createApp;

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

@@ -1,31 +0,0 @@
-{
-  "pages": [
-    "pages/home/home",
-    "pages/my/my"
-  ],
-  "window": {
-    "navigationBarTextStyle": "black",
-    "navigationBarTitleText": "",
-    "navigationBarBackgroundColor": "#B9D9FF"
-  },
-  "tabBar": {
-    "backgroundColor": "#ffffff",
-    "color": "#767676",
-    "selectedColor": "#31B4FF",
-    "list": [
-      {
-        "pagePath": "pages/home/home",
-        "iconPath": "/static/imgs/home.png",
-        "selectedIconPath": "/static/imgs/home-a.png",
-        "text": "首页"
-      },
-      {
-        "pagePath": "pages/my/my",
-        "iconPath": "/static/imgs/my.png",
-        "selectedIconPath": "/static/imgs/my-a.png",
-        "text": "我的"
-      }
-    ]
-  },
-  "usingComponents": {}
-}

+ 0 - 426
unpackage/dist/dev/mp-weixin/app.wxss

@@ -1,426 +0,0 @@
-/**
- * 这里是uni-app内置的常用样式变量
- *
- * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
- * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
- *
- */
-/**
- * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
- *
- * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
- */
-/* 颜色变量 */
-/* 行为相关颜色 */
-/* 文字基本颜色 */
-/* 背景颜色 */
-/* 边框颜色 */
-/* 尺寸变量 */
-/* 文字尺寸 */
-/* 图片尺寸 */
-/* Border Radius */
-/* 水平间距 */
-/* 垂直间距 */
-/* 透明度 */
-/* 文章场景相关 */
-.w100 {
-	width: 100%!important;
-}
-.h100 {
-	height: 100%!important;
-}
-/* 定位 */
-.pos-re {
-	position: relative;
-}
-.pos-ab {
-	position: absolute;
-}
-.box-s {
-	box-sizing: border-box;
-}
-.flex {
-	display: flex;
-}
-.flex-1 {
-	flex: 1;
-}
-.flex-a {
-	display: flex;
-	align-items: center;
-}
-.flex-a-s {
-	align-items: flex-start;
-}
-.flex-a-c {
-	align-items: center;
-}
-.flex-a-e {
-	align-items: flex-end;
-}
-.flex-c {
-	display: flex;
-	align-items: center;
-	justify-content: center;
-}
-.flex-d {
-	display: flex;
-	flex-direction: column;
-}
-.flex-w {
-	display: flex;
-	flex-wrap: wrap;
-}
-.flex-j-a {
-	justify-content: space-around;
-}
-.flex-j-c {
-	justify-content: center;
-}
-.flex-j-b {
-	justify-content: space-between;
-}
-/* 文本仅显示 1 行 */
-.line-1 {
-	width: 100%;
-	white-space: nowrap;
-	text-overflow: ellipsis;
-	overflow: hidden;
-	word-break: break-all;
-}
-/* 文本仅显示 2 行 */
-.line-2 {
-	text-overflow: -o-ellipsis-lastline;
-	overflow: hidden;
-	text-overflow: ellipsis;
-	display: -webkit-box;
-	-webkit-line-clamp: 2;
-	line-clamp: 2;
-	-webkit-box-orient: vertical;
-}
-.m-2 {
-	margin: 20rpx;
-}
-.m-l-1 {
-	margin-left: 10rpx;
-}
-.m-l-2 {
-	margin-left: 20rpx;
-}
-.m-l-3 {
-	margin-left: 30rpx;
-}
-.m-r-1 {
-	margin-right: 10rpx;
-}
-.m-r-2 {
-	margin-right: 20rpx;
-}
-.m-r-3 {
-	margin-right: 30rpx;
-}
-.m-t-0 {
-	margin-top: 0;
-}
-.m-t-1 {
-	margin-top: 10rpx;
-}
-.m-t-2 {
-	margin-top: 20rpx;
-}
-.m-t-3 {
-	margin-top: 30rpx;
-}
-.m-b-2 {
-	margin-bottom: 20rpx;
-}
-.p-2 {
-	padding: 20rpx;
-}
-.p-l-2 {
-	padding-left: 20rpx;
-}
-.p-r-2 {
-	padding-right: 20rpx;
-}
-.p-t-2 {
-	padding-top: 20rpx;
-}
-.p-b-2 {
-	padding-bottom: 20rpx;
-}
-.text-l {
-	text-align: left;
-}
-.text-c {
-	text-align: center;
-}
-.text-r {
-	text-align: right;
-}
-.u-line-1 {
-
-
-
-
-
-
-
-  display: -webkit-box !important;
-  overflow: hidden;
-  text-overflow: ellipsis;
-  word-break: break-all;
-  -webkit-line-clamp: 1;
-  -webkit-box-orient: vertical !important;
-}
-.u-line-2 {
-
-
-
-
-
-
-
-  display: -webkit-box !important;
-  overflow: hidden;
-  text-overflow: ellipsis;
-  word-break: break-all;
-  -webkit-line-clamp: 2;
-  -webkit-box-orient: vertical !important;
-}
-.u-line-3 {
-
-
-
-
-
-
-
-  display: -webkit-box !important;
-  overflow: hidden;
-  text-overflow: ellipsis;
-  word-break: break-all;
-  -webkit-line-clamp: 3;
-  -webkit-box-orient: vertical !important;
-}
-.u-line-4 {
-
-
-
-
-
-
-
-  display: -webkit-box !important;
-  overflow: hidden;
-  text-overflow: ellipsis;
-  word-break: break-all;
-  -webkit-line-clamp: 4;
-  -webkit-box-orient: vertical !important;
-}
-.u-line-5 {
-
-
-
-
-
-
-
-  display: -webkit-box !important;
-  overflow: hidden;
-  text-overflow: ellipsis;
-  word-break: break-all;
-  -webkit-line-clamp: 5;
-  -webkit-box-orient: vertical !important;
-}
-.u-border {
-  border-width: 0.5px !important;
-  border-color: #dadbde !important;
-  border-style: solid;
-}
-.u-border-top {
-  border-top-width: 0.5px !important;
-  border-color: #dadbde !important;
-  border-top-style: solid;
-}
-.u-border-left {
-  border-left-width: 0.5px !important;
-  border-color: #dadbde !important;
-  border-left-style: solid;
-}
-.u-border-right {
-  border-right-width: 0.5px !important;
-  border-color: #dadbde !important;
-  border-right-style: solid;
-}
-.u-border-bottom {
-  border-bottom-width: 0.5px !important;
-  border-color: #dadbde !important;
-  border-bottom-style: solid;
-}
-.u-border-top-bottom {
-  border-top-width: 0.5px !important;
-  border-bottom-width: 0.5px !important;
-  border-color: #dadbde !important;
-  border-top-style: solid;
-  border-bottom-style: solid;
-}
-.u-reset-button {
-  padding: 0;
-  background-color: transparent;
-
-  font-size: inherit;
-  line-height: inherit;
-  color: inherit;
-}
-.u-reset-button::after {
-  border: none;
-}
-.u-hover-class {
-  opacity: 0.7;
-}
-.u-primary-light {
-  color: #ecf5ff;
-}
-.u-warning-light {
-  color: #fdf6ec;
-}
-.u-success-light {
-  color: #f5fff0;
-}
-.u-error-light {
-  color: #fef0f0;
-}
-.u-info-light {
-  color: #f4f4f5;
-}
-.u-primary-light-bg {
-  background-color: #ecf5ff;
-}
-.u-warning-light-bg {
-  background-color: #fdf6ec;
-}
-.u-success-light-bg {
-  background-color: #f5fff0;
-}
-.u-error-light-bg {
-  background-color: #fef0f0;
-}
-.u-info-light-bg {
-  background-color: #f4f4f5;
-}
-.u-primary-dark {
-  color: #398ade;
-}
-.u-warning-dark {
-  color: #f1a532;
-}
-.u-success-dark {
-  color: #53c21d;
-}
-.u-error-dark {
-  color: #e45656;
-}
-.u-info-dark {
-  color: #767a82;
-}
-.u-primary-dark-bg {
-  background-color: #398ade;
-}
-.u-warning-dark-bg {
-  background-color: #f1a532;
-}
-.u-success-dark-bg {
-  background-color: #53c21d;
-}
-.u-error-dark-bg {
-  background-color: #e45656;
-}
-.u-info-dark-bg {
-  background-color: #767a82;
-}
-.u-primary-disabled {
-  color: #9acafc;
-}
-.u-warning-disabled {
-  color: #f9d39b;
-}
-.u-success-disabled {
-  color: #a9e08f;
-}
-.u-error-disabled {
-  color: #f7b2b2;
-}
-.u-info-disabled {
-  color: #c4c6c9;
-}
-.u-primary {
-  color: #3c9cff;
-}
-.u-warning {
-  color: #f9ae3d;
-}
-.u-success {
-  color: #5ac725;
-}
-.u-error {
-  color: #f56c6c;
-}
-.u-info {
-  color: #909399;
-}
-.u-primary-bg {
-  background-color: #3c9cff;
-}
-.u-warning-bg {
-  background-color: #f9ae3d;
-}
-.u-success-bg {
-  background-color: #5ac725;
-}
-.u-error-bg {
-  background-color: #f56c6c;
-}
-.u-info-bg {
-  background-color: #909399;
-}
-.u-main-color {
-  color: #303133;
-}
-.u-content-color {
-  color: #606266;
-}
-.u-tips-color {
-  color: #909193;
-}
-.u-light-color {
-  color: #c0c4cc;
-}
-.u-safe-area-inset-top {
-  padding-top: 0;
-  padding-top: constant(safe-area-inset-top);
-  padding-top: env(safe-area-inset-top);
-}
-.u-safe-area-inset-right {
-  padding-right: 0;
-  padding-right: constant(safe-area-inset-right);
-  padding-right: env(safe-area-inset-right);
-}
-.u-safe-area-inset-bottom {
-  padding-bottom: 0;
-  padding-bottom: constant(safe-area-inset-bottom);
-  padding-bottom: env(safe-area-inset-bottom);
-}
-.u-safe-area-inset-left {
-  padding-left: 0;
-  padding-left: constant(safe-area-inset-left);
-  padding-left: env(safe-area-inset-left);
-}
-::-webkit-scrollbar {
-  display: none;
-  width: 0 !important;
-  height: 0 !important;
-  -webkit-appearance: none;
-  background: transparent;
-}
-/*每个页面公共css */page{--status-bar-height:25px;--top-window-height:0px;--window-top:0px;--window-bottom:0px;--window-left:0px;--window-right:0px;--window-magin:0px}[data-c-h="true"]{display: none !important;}

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

@@ -1,7247 +0,0 @@
-"use strict";
-const _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];
-}
-const toDisplayString = (val) => {
-  return isString(val) ? val : val == null ? "" : isArray(val) || isObject(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(val) && !isArray(val) && !isPlainObject$1(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$1 = Object.prototype.hasOwnProperty;
-const hasOwn = (val, key) => hasOwnProperty$1.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 = (val) => val !== null && typeof val === "object";
-const isPromise = (val) => {
-  return isObject(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$1 = (val) => toTypeString(val) === "[object Object]";
-const isIntegerKey = (key) => isString(key) && key !== "NaN" && key[0] !== "-" && "" + parseInt(key, 10) === key;
-const isReservedProp = /* @__PURE__ */ makeMap(
-  // the leading comma is intentional so empty string "" is also included
-  ",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 looseToNumber = (val) => {
-  const n = parseFloat(val);
-  return isNaN(n) ? val : n;
-};
-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$1(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$1(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
-  };
-})();
-function isUniLifecycleHook(name, value, checkType = true) {
-  if (checkType && !isFunction(value)) {
-    return false;
-  }
-  if (UniLifecycleHooks.indexOf(name) > -1) {
-    return true;
-  } else if (name.indexOf("on") === 0) {
-    return true;
-  }
-  return false;
-}
-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 invokeCreateErrorHandler = once((app, createErrorHandler2) => {
-  if (isFunction(app._component.onError)) {
-    return createErrorHandler2(app);
-  }
-});
-const E = function() {
-};
-E.prototype = {
-  on: function(name, callback, ctx) {
-    var e = this.e || (this.e = {});
-    (e[name] || (e[name] = [])).push({
-      fn: callback,
-      ctx
-    });
-    return this;
-  },
-  once: function(name, callback, ctx) {
-    var self = this;
-    function listener() {
-      self.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 e = this.e || (this.e = {});
-    var evts = e[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 ? e[name] = liveEvents : delete e[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;
-  }
-  let locales = [LOCALE_EN, LOCALE_FR, LOCALE_ES];
-  if (messages && Object.keys(messages).length > 0) {
-    locales = Object.keys(messages);
-  }
-  const lang = startsWith(locale, locales);
-  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$1(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(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 (e) {
-      console.error(e);
-    }
-  };
-}
-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$1(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, params) {
-  return function(data) {
-    return hook(data, params) || data;
-  };
-}
-function queue$1(hooks, data, params) {
-  let promise = false;
-  for (let i = 0; i < hooks.length; i++) {
-    const hook = hooks[i];
-    if (promise) {
-      promise = Promise.resolve(wrapperHook(hook, params));
-    } else {
-      const res = hook(data, params);
-      if (isPromise(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, options).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(getApiInterceptorHooks(method), options2), ...params);
-      });
-    } else {
-      return api(wrapperOptions(interceptor, options), ...params);
-    }
-  }
-  return api(options, ...params);
-}
-function hasCallback(args) {
-  if (isPlainObject$1(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((resolve, reject) => {
-      invokeApi(name, fn, extend(args, { success: resolve, fail: reject }), rest);
-    })));
-  };
-}
-function formatApiArgs(args, options) {
-  const params = args[0];
-  if (!options || !isPlainObject$1(options.formatArgs) && isPlainObject$1(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$1(interceptor)) {
-    mergeInterceptorHook(scopedInterceptors[method] || (scopedInterceptors[method] = {}), interceptor);
-  } else if (isPlainObject$1(method)) {
-    mergeInterceptorHook(globalInterceptors, method);
-  }
-}, AddInterceptorProtocol);
-const removeInterceptor = defineSyncApi(API_REMOVE_INTERCEPTOR, (method, interceptor) => {
-  if (isString(method)) {
-    if (isPlainObject$1(interceptor)) {
-      removeInterceptorHook(scopedInterceptors[method], interceptor);
-    } else {
-      delete scopedInterceptors[method];
-    }
-  } else if (isPlainObject$1(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((n) => emitter.off(n, 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 (e) {
-  }
-  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, reject }) => {
-  Promise.resolve().then(() => {
-    if (typeof enabled === "undefined") {
-      enabled = false;
-      cid = "";
-      cidErrMsg = "uniPush is not enabled";
-    }
-    getPushCidCallbacks.push((cid2, errMsg) => {
-      if (cid2) {
-        resolve({ 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((resolve, reject) => {
-      invokeApi(name, api, extend({}, options, {
-        success: resolve,
-        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$1(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(`微信小程序 ${methodName} 暂不支持 ${key}`);
-          } else if (isString(keyOption)) {
-            toArgs[keyOption] = fromArgs[key];
-          } else if (isPlainObject$1(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(`微信小程序 暂不支持${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 = isFunction(getApp) && getApp({ allowDefault: true });
-  if (app && app.$vm) {
-    return app.$vm.$locale;
-  }
-  return normalizeLocale(wx.getSystemInfoSync().language) || LOCALE_EN;
-};
-const setLocale = (locale) => {
-  const app = isFunction(getApp) && 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 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__1EE8A12",
-    appName: "demo",
-    appVersion: "1.0.0",
-    appVersionCode: "100",
-    appLanguage: getAppLanguage(hostLanguage),
-    uniCompileVersion: "3.8.12",
-    uniRuntimeVersion: "3.8.12",
-    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,
-    // TODO
-    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__1EE8A12",
-      appName: "demo",
-      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 baseApis = {
-  $on,
-  $off,
-  $once,
-  $emit,
-  upx2px,
-  interceptors,
-  addInterceptor,
-  removeInterceptor,
-  onCreateVueApp,
-  invokeCreateVueAppHook,
-  getLocale,
-  setLocale,
-  onLocaleChange,
-  getPushClientId,
-  onPushMessage,
-  offPushMessage,
-  invokePushCallback
-};
-function initUni(api, protocols2, platform = wx) {
-  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, platform[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:服务[" + service + "]不存在"
-      };
-      isFunction(fail) && fail(res);
-    }
-    isFunction(complete) && complete(res);
-  };
-}
-const objectKeys = [
-  "qy",
-  "env",
-  "error",
-  "version",
-  "lanDebug",
-  "cloud",
-  "serviceMarket",
-  "router",
-  "worklet",
-  "__webpack_require_UNI_MP_PLUGIN__"
-];
-const singlePageDisableKey = ["lanDebug", "router", "worklet"];
-const launchOption = wx.getLaunchOptionsSync ? wx.getLaunchOptionsSync() : null;
-function isWxKey(key) {
-  if (launchOption && launchOption.scene === 1154 && singlePageDisableKey.includes(key)) {
-    return false;
-  }
-  return objectKeys.indexOf(key) > -1 || typeof wx[key] === "function";
-}
-function initWx() {
-  const newWx = {};
-  for (const key in wx) {
-    if (isWxKey(key)) {
-      newWx[key] = wx[key];
-    }
-  }
-  if (typeof globalThis !== "undefined" && typeof requireMiniProgram === "undefined") {
-    globalThis.wx = newWx;
-  }
-  return newWx;
-}
-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$2.createSelectorQuery();
-  const oldIn = query.in;
-  query.in = function newIn(component) {
-    return oldIn.call(this, initComponentMocks(component));
-  };
-  return query;
-}
-const wx$2 = initWx();
-let baseInfo = wx$2.getAppBaseInfo && wx$2.getAppBaseInfo();
-if (!baseInfo) {
-  baseInfo = wx$2.getSystemInfoSync();
-}
-const host = baseInfo ? baseInfo.host : null;
-const shareVideoMessage = host && host.env === "SAAASDK" ? wx$2.miniapp.shareVideoMessage : wx$2.shareVideoMessage;
-var shims = /* @__PURE__ */ Object.freeze({
-  __proto__: null,
-  createSelectorQuery,
-  getProvider,
-  shareVideoMessage
-});
-const compressImage = {
-  args(fromArgs, toArgs) {
-    if (fromArgs.compressedHeight && !toArgs.compressHeight) {
-      toArgs.compressHeight = fromArgs.compressedHeight;
-    }
-    if (fromArgs.compressedWidth && !toArgs.compressWidth) {
-      toArgs.compressWidth = fromArgs.compressedWidth;
-    }
-  }
-};
-var protocols = /* @__PURE__ */ Object.freeze({
-  __proto__: null,
-  compressImage,
-  getAppAuthorizeSetting,
-  getAppBaseInfo,
-  getDeviceInfo,
-  getSystemInfo,
-  getSystemInfoSync,
-  getWindowInfo,
-  previewImage,
-  redirectTo,
-  showActionSheet
-});
-const wx$1 = initWx();
-var index = initUni(shims, protocols, wx$1);
-function warn$1(msg, ...args) {
-  console.warn(`[Vue warn] ${msg}`, ...args);
-}
-let activeEffectScope;
-class EffectScope {
-  constructor(detached = false) {
-    this.detached = detached;
-    this._active = true;
-    this.effects = [];
-    this.cleanups = [];
-    this.parent = activeEffectScope;
-    if (!detached && activeEffectScope) {
-      this.index = (activeEffectScope.scopes || (activeEffectScope.scopes = [])).push(this) - 1;
-    }
-  }
-  get active() {
-    return this._active;
-  }
-  run(fn) {
-    if (this._active) {
-      const currentEffectScope = activeEffectScope;
-      try {
-        activeEffectScope = this;
-        return fn();
-      } finally {
-        activeEffectScope = currentEffectScope;
-      }
-    } else {
-      warn$1(`cannot run an inactive effect scope.`);
-    }
-  }
-  /**
-   * This should only be called on non-detached scopes
-   * @internal
-   */
-  on() {
-    activeEffectScope = this;
-  }
-  /**
-   * This should only be called on non-detached scopes
-   * @internal
-   */
-  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.detached && this.parent && !fromParent) {
-        const last = this.parent.scopes.pop();
-        if (last && last !== this) {
-          this.parent.scopes[this.index] = last;
-          last.index = this.index;
-        }
-      }
-      this.parent = void 0;
-      this._active = false;
-    }
-  }
-}
-function effectScope(detached) {
-  return new EffectScope(detached);
-}
-function recordEffectScope(effect, scope = activeEffectScope) {
-  if (scope && scope.active) {
-    scope.effects.push(effect);
-  }
-}
-function getCurrentScope() {
-  return activeEffectScope;
-}
-function onScopeDispose(fn) {
-  if (activeEffectScope) {
-    activeEffectScope.cleanups.push(fn);
-  } else {
-    warn$1(`onScopeDispose() is called when there is no active effect scope to be associated with.`);
-  }
-}
-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)) {
-    const newLength = Number(newValue);
-    depsMap.forEach((dep, key2) => {
-      if (key2 === "length" || key2 >= newLength) {
-        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();
-    }
-  }
-}
-function getDepFromReactive(object, key) {
-  var _a2;
-  return (_a2 = targetMap.get(object)) === null || _a2 === void 0 ? void 0 : _a2.get(key);
-}
-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$1 = /* @__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 hasOwnProperty(key) {
-  const obj = toRaw(this);
-  track(obj, "has", key);
-  return obj.hasOwnProperty(key);
-}
-function createGetter(isReadonly2 = false, shallow = false) {
-  return function get2(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) {
-      if (targetIsArray && hasOwn(arrayInstrumentations, key)) {
-        return Reflect.get(arrayInstrumentations, key, receiver);
-      }
-      if (key === "hasOwnProperty") {
-        return hasOwnProperty;
-      }
-    }
-    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(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) {
-      if (!isShallow(value) && !isReadonly(value)) {
-        oldValue = toRaw(oldValue);
-        value = toRaw(value);
-      }
-      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$1(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: get$1,
-  set: set$1,
-  deleteProperty,
-  has: has$1,
-  ownKeys
-};
-const readonlyHandlers = {
-  get: readonlyGet,
-  set(target, key) {
-    {
-      warn$1(`Set operation on key "${String(key)}" failed: target is readonly.`, target);
-    }
-    return true;
-  },
-  deleteProperty(target, key) {
-    {
-      warn$1(`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(target, key, isReadonly2 = false, isShallow2 = false) {
-  target = target[
-    "__v_raw"
-    /* ReactiveFlags.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(key, isReadonly2 = false) {
-  const target = this[
-    "__v_raw"
-    /* ReactiveFlags.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"
-    /* ReactiveFlags.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$2(key, value) {
-  value = toRaw(value);
-  const target = toRaw(this);
-  const { has: has2, get: get2 } = 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 = get2.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: get2 } = 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 = get2 ? get2.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"
-      /* ReactiveFlags.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"
-      /* ReactiveFlags.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 {
-      // iterator protocol
-      next() {
-        const { value, done } = innerIterator.next();
-        return done ? { value, done } : {
-          value: isPair ? [wrap(value[0]), wrap(value[1])] : wrap(value),
-          done
-        };
-      },
-      // iterable protocol
-      [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(this, key);
-    },
-    get size() {
-      return size(this);
-    },
-    has,
-    add,
-    set: set$2,
-    delete: deleteEntry,
-    clear,
-    forEach: createForEach(false, false)
-  };
-  const shallowInstrumentations2 = {
-    get(key) {
-      return get(this, key, false, true);
-    },
-    get size() {
-      return size(this);
-    },
-    has,
-    add,
-    set: set$2,
-    delete: deleteEntry,
-    clear,
-    forEach: createForEach(false, true)
-  };
-  const readonlyInstrumentations2 = {
-    get(key) {
-      return get(this, key, true);
-    },
-    get size() {
-      return size(this, true);
-    },
-    has(key) {
-      return has.call(this, key, true);
-    },
-    add: createReadonlyMethod(
-      "add"
-      /* TriggerOpTypes.ADD */
-    ),
-    set: createReadonlyMethod(
-      "set"
-      /* TriggerOpTypes.SET */
-    ),
-    delete: createReadonlyMethod(
-      "delete"
-      /* TriggerOpTypes.DELETE */
-    ),
-    clear: createReadonlyMethod(
-      "clear"
-      /* TriggerOpTypes.CLEAR */
-    ),
-    forEach: createForEach(true, false)
-  };
-  const shallowReadonlyInstrumentations2 = {
-    get(key) {
-      return get(this, key, true, true);
-    },
-    get size() {
-      return size(this, true);
-    },
-    has(key) {
-      return has.call(this, key, true);
-    },
-    add: createReadonlyMethod(
-      "add"
-      /* TriggerOpTypes.ADD */
-    ),
-    set: createReadonlyMethod(
-      "set"
-      /* TriggerOpTypes.SET */
-    ),
-    delete: createReadonlyMethod(
-      "delete"
-      /* TriggerOpTypes.DELETE */
-    ),
-    clear: createReadonlyMethod(
-      "clear"
-      /* TriggerOpTypes.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"
-    /* ReactiveFlags.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(target)) {
-    {
-      console.warn(`value cannot be made reactive: ${String(target)}`);
-    }
-    return target;
-  }
-  if (target[
-    "__v_raw"
-    /* ReactiveFlags.RAW */
-  ] && !(isReadonly2 && target[
-    "__v_isReactive"
-    /* ReactiveFlags.IS_REACTIVE */
-  ])) {
-    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"
-      /* ReactiveFlags.RAW */
-    ]);
-  }
-  return !!(value && value[
-    "__v_isReactive"
-    /* ReactiveFlags.IS_REACTIVE */
-  ]);
-}
-function isReadonly(value) {
-  return !!(value && value[
-    "__v_isReadonly"
-    /* ReactiveFlags.IS_READONLY */
-  ]);
-}
-function isShallow(value) {
-  return !!(value && value[
-    "__v_isShallow"
-    /* ReactiveFlags.IS_SHALLOW */
-  ]);
-}
-function isProxy(value) {
-  return isReactive(value) || isReadonly(value);
-}
-function toRaw(observed) {
-  const raw = observed && observed[
-    "__v_raw"
-    /* ReactiveFlags.RAW */
-  ];
-  return raw ? toRaw(raw) : observed;
-}
-function markRaw(value) {
-  def(value, "__v_skip", true);
-  return value;
-}
-const toReactive = (value) => isObject(value) ? reactive(value) : value;
-const toReadonly = (value) => isObject(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);
-  const dep = ref2.dep;
-  if (dep) {
-    {
-      triggerEffects(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 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) {
-    const useDirectValue = this.__v_isShallow || isShallow(newVal) || isReadonly(newVal);
-    newVal = useDirectValue ? newVal : toRaw(newVal);
-    if (hasChanged(newVal, this._rawValue)) {
-      this._rawValue = newVal;
-      this._value = useDirectValue ? 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;
-  }
-  get dep() {
-    return getDepFromReactive(toRaw(this._object), this._key);
-  }
-}
-function toRef(object, key, defaultValue) {
-  const val = object[key];
-  return isRef(val) ? val : new ObjectRefImpl(object, key, defaultValue);
-}
-var _a;
-class ComputedRefImpl {
-  constructor(getter, _setter, isReadonly2, isSSR) {
-    this._setter = _setter;
-    this.dep = void 0;
-    this.__v_isRef = true;
-    this[_a] = false;
-    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"
-      /* ReactiveFlags.IS_READONLY */
-    ] = isReadonly2;
-  }
-  get value() {
-    const self = toRaw(this);
-    trackRefValue(self);
-    if (self._dirty || !self._cacheable) {
-      self._dirty = false;
-      self._value = self.effect.run();
-    }
-    return self._value;
-  }
-  set value(newValue) {
-    this._setter(newValue);
-  }
-}
-_a = "__v_isReadonly";
-function computed$1(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(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 && // avoid spamming console during tests
-    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"
-    /* LifecycleHooks.SERVER_PREFETCH */
-  ]: "serverPrefetch hook",
-  [
-    "bc"
-    /* LifecycleHooks.BEFORE_CREATE */
-  ]: "beforeCreate hook",
-  [
-    "c"
-    /* LifecycleHooks.CREATED */
-  ]: "created hook",
-  [
-    "bm"
-    /* LifecycleHooks.BEFORE_MOUNT */
-  ]: "beforeMount hook",
-  [
-    "m"
-    /* LifecycleHooks.MOUNTED */
-  ]: "mounted hook",
-  [
-    "bu"
-    /* LifecycleHooks.BEFORE_UPDATE */
-  ]: "beforeUpdate hook",
-  [
-    "u"
-    /* LifecycleHooks.UPDATED */
-  ]: "updated",
-  [
-    "bum"
-    /* LifecycleHooks.BEFORE_UNMOUNT */
-  ]: "beforeUnmount hook",
-  [
-    "um"
-    /* LifecycleHooks.UNMOUNTED */
-  ]: "unmounted hook",
-  [
-    "a"
-    /* LifecycleHooks.ACTIVATED */
-  ]: "activated hook",
-  [
-    "da"
-    /* LifecycleHooks.DEACTIVATED */
-  ]: "deactivated hook",
-  [
-    "ec"
-    /* LifecycleHooks.ERROR_CAPTURED */
-  ]: "errorCaptured hook",
-  [
-    "rtc"
-    /* LifecycleHooks.RENDER_TRACKED */
-  ]: "renderTracked hook",
-  [
-    "rtg"
-    /* LifecycleHooks.RENDER_TRIGGERED */
-  ]: "renderTriggered hook",
-  [
-    0
-    /* ErrorCodes.SETUP_FUNCTION */
-  ]: "setup function",
-  [
-    1
-    /* ErrorCodes.RENDER_FUNCTION */
-  ]: "render function",
-  [
-    2
-    /* ErrorCodes.WATCH_GETTER */
-  ]: "watcher getter",
-  [
-    3
-    /* ErrorCodes.WATCH_CALLBACK */
-  ]: "watcher callback",
-  [
-    4
-    /* ErrorCodes.WATCH_CLEANUP */
-  ]: "watcher cleanup function",
-  [
-    5
-    /* ErrorCodes.NATIVE_EVENT_HANDLER */
-  ]: "native event handler",
-  [
-    6
-    /* ErrorCodes.COMPONENT_EVENT_HANDLER */
-  ]: "component event handler",
-  [
-    7
-    /* ErrorCodes.VNODE_HOOK */
-  ]: "vnode hook",
-  [
-    8
-    /* ErrorCodes.DIRECTIVE_HOOK */
-  ]: "directive hook",
-  [
-    9
-    /* ErrorCodes.TRANSITION_HOOK */
-  ]: "transition hook",
-  [
-    10
-    /* ErrorCodes.APP_ERROR_HANDLER */
-  ]: "app errorHandler",
-  [
-    11
-    /* ErrorCodes.APP_WARN_HANDLER */
-  ]: "app warnHandler",
-  [
-    12
-    /* ErrorCodes.FUNCTION_REF */
-  ]: "ref function",
-  [
-    13
-    /* ErrorCodes.ASYNC_COMPONENT_LOADER */
-  ]: "async component loader",
-  [
-    14
-    /* ErrorCodes.SCHEDULER */
-  ]: "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(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(`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 pendingPostFlushCbs = [];
-let activePostFlushCbs = null;
-let postFlushIndex = 0;
-const resolvedPromise = /* @__PURE__ */ Promise.resolve();
-let currentFlushPromise = null;
-const RECURSION_LIMIT = 100;
-function nextTick$1(fn) {
-  const p = currentFlushPromise || resolvedPromise;
-  return fn ? p.then(this ? fn.bind(this) : fn) : p;
-}
-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)) {
-    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 queuePostFlushCb(cb) {
-  if (!isArray(cb)) {
-    if (!activePostFlushCbs || !activePostFlushCbs.includes(cb, cb.allowRecurse ? postFlushIndex + 1 : postFlushIndex)) {
-      pendingPostFlushCbs.push(cb);
-    }
-  } else {
-    pendingPostFlushCbs.push(...cb);
-  }
-  queueFlush();
-}
-function flushPreFlushCbs(seen, i = isFlushing ? flushIndex + 1 : 0) {
-  {
-    seen = seen || /* @__PURE__ */ new Map();
-  }
-  for (; i < queue.length; i++) {
-    const cb = queue[i];
-    if (cb && cb.pre) {
-      if (checkRecursiveUpdates(seen, cb)) {
-        continue;
-      }
-      queue.splice(i, 1);
-      i--;
-      cb();
-    }
-  }
-}
-function flushPostFlushCbs(seen) {
-  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;
-const comparator = (a, b) => {
-  const diff2 = getId(a) - getId(b);
-  if (diff2 === 0) {
-    if (a.pre && !b.pre)
-      return -1;
-    if (b.pre && !a.pre)
-      return 1;
-  }
-  return diff2;
-};
-function flushJobs(seen) {
-  isFlushPending = false;
-  isFlushing = true;
-  {
-    seen = seen || /* @__PURE__ */ new Map();
-  }
-  queue.sort(comparator);
-  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
-          /* ErrorCodes.SCHEDULER */
-        );
-      }
-    }
-  } finally {
-    flushIndex = 0;
-    queue.length = 0;
-    flushPostFlushCbs(seen);
-    isFlushing = false;
-    currentFlushPromise = null;
-    if (queue.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(`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);
-    }
-  }
-}
-let devtools;
-let buffer = [];
-let devtoolsNotInstalled = false;
-function emit$1(event, ...args) {
-  if (devtools) {
-    devtools.emit(event, ...args);
-  } else if (!devtoolsNotInstalled) {
-    buffer.push({ event, args });
-  }
-}
-function setDevtoolsHook(hook, target) {
-  var _a2, _b;
-  devtools = hook;
-  if (devtools) {
-    devtools.enabled = true;
-    buffer.forEach(({ event, args }) => devtools.emit(event, ...args));
-    buffer = [];
-  } else if (
-    // handle late devtools injection - only do this if we are in an actual
-    // browser environment to avoid the timer handle stalling test runner exit
-    // (#4815)
-    typeof window !== "undefined" && // some envs mock window but not fully
-    // eslint-disable-next-line no-restricted-globals
-    window.HTMLElement && // also exclude jsdom
-    // eslint-disable-next-line no-restricted-globals
-    !((_b = (_a2 = window.navigator) === null || _a2 === void 0 ? void 0 : _a2.userAgent) === null || _b === void 0 ? void 0 : _b.includes("jsdom"))
-  ) {
-    const replay = target.__VUE_DEVTOOLS_HOOK_REPLAY__ = target.__VUE_DEVTOOLS_HOOK_REPLAY__ || [];
-    replay.push((newHook) => {
-      setDevtoolsHook(newHook, target);
-    });
-    setTimeout(() => {
-      if (!devtools) {
-        target.__VUE_DEVTOOLS_HOOK_REPLAY__ = null;
-        devtoolsNotInstalled = true;
-        buffer = [];
-      }
-    }, 3e3);
-  } else {
-    devtoolsNotInstalled = true;
-    buffer = [];
-  }
-}
-function devtoolsInitApp(app, version2) {
-  emit$1("app:init", app, version2, {
-    Fragment,
-    Text,
-    Comment,
-    Static
-  });
-}
-const devtoolsComponentAdded = /* @__PURE__ */ createDevtoolsComponentHook(
-  "component:added"
-  /* DevtoolsHooks.COMPONENT_ADDED */
-);
-const devtoolsComponentUpdated = /* @__PURE__ */ createDevtoolsComponentHook(
-  "component:updated"
-  /* DevtoolsHooks.COMPONENT_UPDATED */
-);
-const _devtoolsComponentRemoved = /* @__PURE__ */ createDevtoolsComponentHook(
-  "component:removed"
-  /* DevtoolsHooks.COMPONENT_REMOVED */
-);
-const devtoolsComponentRemoved = (component) => {
-  if (devtools && typeof devtools.cleanupBuffer === "function" && // remove the component if it wasn't buffered
-  !devtools.cleanupBuffer(component)) {
-    _devtoolsComponentRemoved(component);
-  }
-};
-function createDevtoolsComponentHook(hook) {
-  return (component) => {
-    emit$1(
-      hook,
-      component.appContext.app,
-      component.uid,
-      // fixed by xxxxxx
-      // 为 0 是 App,无 parent 是 Page 指向 App
-      component.uid === 0 ? void 0 : component.parent ? component.parent.uid : 0,
-      component
-    );
-  };
-}
-const devtoolsPerfStart = /* @__PURE__ */ createDevtoolsPerformanceHook(
-  "perf:start"
-  /* DevtoolsHooks.PERFORMANCE_START */
-);
-const devtoolsPerfEnd = /* @__PURE__ */ createDevtoolsPerformanceHook(
-  "perf:end"
-  /* DevtoolsHooks.PERFORMANCE_END */
-);
-function createDevtoolsPerformanceHook(hook) {
-  return (component, type, time) => {
-    emit$1(hook, component.appContext.app, component.uid, component, type, time);
-  };
-}
-function devtoolsComponentEmit(component, event, params) {
-  emit$1("component:emit", component.appContext.app, component, event, params);
-}
-function emit(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(`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(`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) => isString(a) ? a.trim() : a);
-    }
-    if (number) {
-      args = rawArgs.map(looseToNumber);
-    }
-  }
-  {
-    devtoolsComponentEmit(instance, event, args);
-  }
-  {
-    const lowerCaseEvent = event.toLowerCase();
-    if (lowerCaseEvent !== event && props[toHandlerKey(lowerCaseEvent)]) {
-      warn(`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)] || // also try camelCase event handler (#2249)
-  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) {
-    if (isObject(comp)) {
-      cache.set(comp, null);
-    }
-    return null;
-  }
-  if (isArray(raw)) {
-    raw.forEach((key) => normalized[key] = null);
-  } else {
-    extend(normalized, raw);
-  }
-  if (isObject(comp)) {
-    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(`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(`injection "${String(key)}" not found.`);
-    }
-  } else {
-    warn(`inject() can only be used inside setup() or functional components.`);
-  }
-}
-const INITIAL_WATCHER_VALUE = {};
-function watch(source, cb, options) {
-  if (!isFunction(cb)) {
-    warn(`\`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(`watch() "immediate" option is only respected when using the watch(source, callback, options?) signature.`);
-    }
-    if (deep !== void 0) {
-      warn(`watch() "deep" option is only respected when using the watch(source, callback, options?) signature.`);
-    }
-  }
-  const warnInvalidSource = (s) => {
-    warn(`Invalid watch source: `, s, `A watch source can only be a getter/effect function, a ref, a reactive object, or an array of these types.`);
-  };
-  const instance = getCurrentScope() === (currentInstance === null || currentInstance === void 0 ? void 0 : currentInstance.scope) ? currentInstance : null;
-  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((s) => isReactive(s) || isShallow(s));
-    getter = () => source.map((s) => {
-      if (isRef(s)) {
-        return s.value;
-      } else if (isReactive(s)) {
-        return traverse(s);
-      } else if (isFunction(s)) {
-        return callWithErrorHandling(
-          s,
-          instance,
-          2
-          /* ErrorCodes.WATCH_GETTER */
-        );
-      } else {
-        warnInvalidSource(s);
-      }
-    });
-  } else if (isFunction(source)) {
-    if (cb) {
-      getter = () => callWithErrorHandling(
-        source,
-        instance,
-        2
-        /* ErrorCodes.WATCH_GETTER */
-      );
-    } 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
-        /* ErrorCodes.WATCH_CLEANUP */
-      );
-    };
-  };
-  let oldValue = isMultiSource ? new Array(source.length).fill(INITIAL_WATCHER_VALUE) : 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,
-          // pass undefined as the old value when it's changed for the first time
-          oldValue === INITIAL_WATCHER_VALUE ? void 0 : isMultiSource && oldValue[0] === INITIAL_WATCHER_VALUE ? [] : oldValue,
-          onCleanup
-        ]);
-        oldValue = newValue;
-      }
-    } else {
-      effect.run();
-    }
-  };
-  job.allowRecurse = !!cb;
-  let scheduler;
-  if (flush === "sync") {
-    scheduler = job;
-  } else if (flush === "post") {
-    scheduler = () => queuePostRenderEffect$1(job, instance && instance.suspense);
-  } else {
-    job.pre = true;
-    if (instance)
-      job.id = instance.uid;
-    scheduler = () => queueJob(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$1(effect.run.bind(effect), instance && instance.suspense);
-  } else {
-    effect.run();
-  }
-  const unwatch = () => {
-    effect.stop();
-    if (instance && instance.scope) {
-      remove(instance.scope.effects, effect);
-    }
-  };
-  return unwatch;
-}
-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(value) || value[
-    "__v_skip"
-    /* ReactiveFlags.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$1(value)) {
-    for (const key in value) {
-      traverse(value[key], seen);
-    }
-  }
-  return value;
-}
-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
-    /* prepend */
-  );
-  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(`${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) => (
-  // post-create lifecycle registrations are noops during SSR (except for serverPrefetch)
-  (!isInSSRComponentSetup || lifecycle === "sp") && injectHook(lifecycle, (...args) => hook(...args), target)
-);
-const onBeforeMount = createHook$1(
-  "bm"
-  /* LifecycleHooks.BEFORE_MOUNT */
-);
-const onMounted = createHook$1(
-  "m"
-  /* LifecycleHooks.MOUNTED */
-);
-const onBeforeUpdate = createHook$1(
-  "bu"
-  /* LifecycleHooks.BEFORE_UPDATE */
-);
-const onUpdated = createHook$1(
-  "u"
-  /* LifecycleHooks.UPDATED */
-);
-const onBeforeUnmount = createHook$1(
-  "bum"
-  /* LifecycleHooks.BEFORE_UNMOUNT */
-);
-const onUnmounted = createHook$1(
-  "um"
-  /* LifecycleHooks.UNMOUNTED */
-);
-const onServerPrefetch = createHook$1(
-  "sp"
-  /* LifecycleHooks.SERVER_PREFETCH */
-);
-const onRenderTriggered = createHook$1(
-  "rtg"
-  /* LifecycleHooks.RENDER_TRIGGERED */
-);
-const onRenderTracked = createHook$1(
-  "rtc"
-  /* LifecycleHooks.RENDER_TRACKED */
-);
-function onErrorCaptured(hook, target = currentInstance) {
-  injectHook("ec", hook, target);
-}
-function validateDirectiveName(name) {
-  if (isBuiltInDirective(name)) {
-    warn("Do not use built-in directive ids as custom directive id: " + name);
-  }
-}
-const getPublicInstance = (i) => {
-  if (!i)
-    return null;
-  if (isStatefulComponent(i))
-    return getExposeProxy(i) || i.proxy;
-  return getPublicInstance(i.parent);
-};
-const publicPropertiesMap = (
-  // Move PURE marker to new line to workaround compiler discarding it
-  // due to type annotation
-  /* @__PURE__ */ extend(/* @__PURE__ */ Object.create(null), {
-    $: (i) => i,
-    // fixed by xxxxxx vue-i18n 在 dev 模式,访问了 $el,故模拟一个假的
-    // $el: i => i.vnode.el,
-    $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)),
-    // $nextTick: i => i.n || (i.n = nextTick.bind(i.proxy!)),// fixed by xxxxxx
-    $watch: (i) => instanceWatch.bind(i)
-  })
-);
-const isReservedPrefix = (key) => key === "_" || key === "$";
-const hasSetupBinding = (state, key) => state !== EMPTY_OBJ && !state.__isScriptSetup && hasOwn(state, key);
-const PublicInstanceProxyHandlers = {
-  get({ _: instance }, key) {
-    const { ctx, setupState, data, props, accessCache, type, appContext } = instance;
-    if (key === "__isVue") {
-      return true;
-    }
-    let normalizedProps;
-    if (key[0] !== "$") {
-      const n = accessCache[key];
-      if (n !== void 0) {
-        switch (n) {
-          case 1:
-            return setupState[key];
-          case 2:
-            return data[key];
-          case 4:
-            return ctx[key];
-          case 3:
-            return props[key];
-        }
-      } else if (hasSetupBinding(setupState, key)) {
-        accessCache[key] = 1;
-        return setupState[key];
-      } else if (data !== EMPTY_OBJ && hasOwn(data, key)) {
-        accessCache[key] = 2;
-        return data[key];
-      } else if (
-        // only cache other properties when instance has declared (thus stable)
-        // props
-        (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 (
-      // css module (injected by vue-loader)
-      (cssModule = type.__cssModules) && (cssModule = cssModule[key])
-    ) {
-      return cssModule;
-    } else if (ctx !== EMPTY_OBJ && hasOwn(ctx, key)) {
-      accessCache[key] = 4;
-      return ctx[key];
-    } else if (
-      // global properties
-      globalProperties = appContext.config.globalProperties, hasOwn(globalProperties, key)
-    ) {
-      {
-        return globalProperties[key];
-      }
-    } else if (currentRenderingInstance && (!isString(key) || // #1091 avoid internal isRef/isVNode checks on component instance leading
-    // to infinite warning loop
-    key.indexOf("__v") !== 0)) {
-      if (data !== EMPTY_OBJ && isReservedPrefix(key[0]) && hasOwn(data, key)) {
-        warn(`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(`Property ${JSON.stringify(key)} was accessed during render but is not defined on instance.`);
-      }
-    }
-  },
-  set({ _: instance }, key, value) {
-    const { data, setupState, ctx } = instance;
-    if (hasSetupBinding(setupState, key)) {
-      setupState[key] = value;
-      return true;
-    } else if (setupState.__isScriptSetup && hasOwn(setupState, key)) {
-      warn(`Cannot mutate <script setup> binding "${key}" from Options API.`);
-      return false;
-    } else if (data !== EMPTY_OBJ && hasOwn(data, key)) {
-      data[key] = value;
-      return true;
-    } else if (hasOwn(instance.props, key)) {
-      warn(`Attempting to mutate prop "${key}". Props are readonly.`);
-      return false;
-    }
-    if (key[0] === "$" && key.slice(1) in instance) {
-      warn(`Attempting to mutate public property "${key}". Properties starting with $ are reserved and readonly.`);
-      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) || hasSetupBinding(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(`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),
-      // intercepted by the proxy so no need for implementation,
-      // but needed to prevent set errors
-      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(`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(`${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"
-      /* LifecycleHooks.BEFORE_CREATE */
-    );
-  }
-  const {
-    // state
-    data: dataOptions,
-    computed: computedOptions,
-    methods,
-    watch: watchOptions,
-    provide: provideOptions,
-    inject: injectOptions,
-    // lifecycle
-    created,
-    beforeMount,
-    mounted,
-    beforeUpdate,
-    updated,
-    activated,
-    deactivated,
-    beforeDestroy,
-    beforeUnmount,
-    destroyed,
-    unmounted,
-    render,
-    renderTracked,
-    renderTriggered,
-    errorCaptured,
-    serverPrefetch,
-    // public API
-    expose,
-    inheritAttrs,
-    // assets
-    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(`Method "${key}" has type "${typeof methodHandler}" in the component definition. Did you reference the function correctly?`);
-      }
-    }
-  }
-  if (dataOptions) {
-    if (!isFunction(dataOptions)) {
-      warn(`The data option must be a function. Plain object usage is no longer supported.`);
-    }
-    const data = dataOptions.call(publicThis, publicThis);
-    if (isPromise(data)) {
-      warn(`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(data)) {
-      warn(`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 get2 = isFunction(opt) ? opt.bind(publicThis, publicThis) : isFunction(opt.get) ? opt.get.bind(publicThis, publicThis) : NOOP;
-      if (get2 === NOOP) {
-        warn(`Computed property "${key}" has no getter.`);
-      }
-      const set2 = !isFunction(opt) && isFunction(opt.set) ? opt.set.bind(publicThis) : () => {
-        warn(`Write operation failed: computed property "${key}" is readonly.`);
-      };
-      const c = computed({
-        get: get2,
-        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"
-        /* LifecycleHooks.CREATED */
-      );
-    }
-  }
-  function registerLifecycleHook(register, hook) {
-    if (isArray(hook)) {
-      hook.forEach((_hook) => register(_hook.bind(publicThis)));
-    } else if (hook) {
-      register(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(opt)) {
-      if ("default" in opt) {
-        injected = inject(
-          opt.from || key,
-          opt.default,
-          true
-          /* treat default function as factory */
-        );
-      } 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(`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(`Invalid watch handler specified by key "${raw}"`, handler);
-    }
-  } else if (isFunction(raw)) {
-    watch(getter, raw.bind(publicThis));
-  } else if (isObject(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(`Invalid watch handler specified by key "${raw.handler}"`, handler);
-      }
-    }
-  } else {
-    warn(`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);
-  }
-  if (isObject(base)) {
-    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(`"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,
-  // objects
-  methods: mergeObjectOptions,
-  computed: mergeObjectOptions,
-  // lifecycle
-  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,
-  // assets
-  components: mergeObjectOptions,
-  directives: mergeObjectOptions,
-  // watch
-  watch: mergeWatchOptions,
-  // provide / inject
-  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 isInHmrContext(instance) {
-  while (instance) {
-    if (instance.type.__hmrId)
-      return true;
-    instance = instance.parent;
-  }
-}
-function updateProps(instance, rawProps, rawPrevProps, optimized) {
-  const { props, attrs, vnode: { patchFlag } } = instance;
-  const rawCurrentProps = toRaw(props);
-  const [options] = instance.propsOptions;
-  let hasAttrsChanged = false;
-  if (
-    // always force full diff in dev
-    // - #1942 if hmr is enabled with sfc component
-    // - vite#872 non-sfc component used by sfc component
-    !isInHmrContext(instance) && (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
-              /* isAbsent */
-            );
-          }
-        } 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 || // for camelCase
-      !hasOwn(rawProps, key) && // it's possible the original props was passed in as kebab-case
-      // and converted to camelCase (#955)
-      ((kebabKey = hyphenate(key)) === key || !hasOwn(rawProps, kebabKey))) {
-        if (options) {
-          if (rawPrevProps && // for camelCase
-          (rawPrevProps[key] !== void 0 || // for kebab-case
-          rawPrevProps[kebabKey] !== void 0)) {
-            props[key] = resolvePropValue(
-              options,
-              rawCurrentProps,
-              key,
-              void 0,
-              instance,
-              true
-              /* isAbsent */
-            );
-          }
-        } 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
-      /* BooleanFlags.shouldCast */
-    ]) {
-      if (isAbsent && !hasDefault) {
-        value = false;
-      } else if (opt[
-        1
-        /* BooleanFlags.shouldCastTrue */
-      ] && (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) {
-    if (isObject(comp)) {
-      cache.set(comp, EMPTY_ARR);
-    }
-    return EMPTY_ARR;
-  }
-  if (isArray(raw)) {
-    for (let i = 0; i < raw.length; i++) {
-      if (!isString(raw[i])) {
-        warn(`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(raw)) {
-      warn(`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 } : Object.assign({}, opt);
-        if (prop) {
-          const booleanIndex = getTypeIndex(Boolean, prop.type);
-          const stringIndex = getTypeIndex(String, prop.type);
-          prop[
-            0
-            /* BooleanFlags.shouldCast */
-          ] = booleanIndex > -1;
-          prop[
-            1
-            /* BooleanFlags.shouldCastTrue */
-          ] = stringIndex < 0 || booleanIndex < stringIndex;
-          if (booleanIndex > -1 || hasOwn(prop, "default")) {
-            needCastKeys.push(normalizedKey);
-          }
-        }
-      }
-    }
-  }
-  const res = [normalized, needCastKeys];
-  if (isObject(comp)) {
-    cache.set(comp, res);
-  }
-  return res;
-}
-function validatePropName(key) {
-  if (key[0] !== "$") {
-    return true;
-  } else {
-    warn(`Invalid prop name: "${key}" is a reserved property.`);
-  }
-  return false;
-}
-function getType(ctor) {
-  const match = ctor && ctor.toString().match(/^\s*(function|class) (\w+)/);
-  return match ? match[2] : 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('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(getInvalidTypeMessage(name, value, expectedTypes));
-      return;
-    }
-  }
-  if (validator && !validator(value)) {
-    warn('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(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$1 = 0;
-function createAppAPI(render, hydrate) {
-  return function createApp2(rootComponent, rootProps = null) {
-    if (!isFunction(rootComponent)) {
-      rootComponent = Object.assign({}, rootComponent);
-    }
-    if (rootProps != null && !isObject(rootProps)) {
-      warn(`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$1++,
-      _component: rootComponent,
-      _props: rootProps,
-      _container: null,
-      _context: context,
-      _instance: null,
-      version,
-      get config() {
-        return context.config;
-      },
-      set config(v) {
-        {
-          warn(`app.config cannot be replaced. Modify individual options instead.`);
-        }
-      },
-      use(plugin2, ...options) {
-        if (installedPlugins.has(plugin2)) {
-          warn(`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(`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("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(`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(`Directive "${name}" has already been registered in target app.`);
-        }
-        context.directives[name] = directive;
-        return app;
-      },
-      // fixed by xxxxxx
-      mount() {
-      },
-      // fixed by xxxxxx
-      unmount() {
-      },
-      provide(key, value) {
-        if (key in context.provides) {
-          warn(`App already provides property with key "${String(key)}". It will be overwritten with the new value.`);
-        }
-        context.provides[key] = value;
-        return app;
-      }
-    };
-    return app;
-  };
-}
-let supported;
-let perf;
-function startMeasure(instance, type) {
-  if (instance.appContext.config.performance && isSupported()) {
-    perf.mark(`vue-${type}-${instance.uid}`);
-  }
-  {
-    devtoolsPerfStart(instance, type, isSupported() ? perf.now() : Date.now());
-  }
-}
-function endMeasure(instance, type) {
-  if (instance.appContext.config.performance && isSupported()) {
-    const startTag = `vue-${type}-${instance.uid}`;
-    const endTag = startTag + `:end`;
-    perf.mark(endTag);
-    perf.measure(`<${formatComponentName(instance, instance.type)}> ${type}`, startTag, endTag);
-    perf.clearMarks(startTag);
-    perf.clearMarks(endTag);
-  }
-  {
-    devtoolsPerfEnd(instance, type, isSupported() ? perf.now() : Date.now());
-  }
-}
-function isSupported() {
-  if (supported !== void 0) {
-    return supported;
-  }
-  if (typeof window !== "undefined" && window.performance) {
-    supported = true;
-    perf = window.performance;
-  } else {
-    supported = false;
-  }
-  return supported;
-}
-const queuePostRenderEffect$1 = queuePostFlushCb;
-const Fragment = Symbol("Fragment");
-const Text = Symbol("Text");
-const Comment = Symbol("Comment");
-const Static = Symbol("Static");
-function isVNode(value) {
-  return value ? value.__v_isVNode === true : false;
-}
-const emptyAppContext = createAppContext();
-let uid = 0;
-function createComponentInstance(vnode, parent, suspense) {
-  const type = vnode.type;
-  const appContext = (parent ? parent.appContext : vnode.appContext) || emptyAppContext;
-  const instance = {
-    uid: uid++,
-    vnode,
-    type,
-    parent,
-    appContext,
-    root: null,
-    next: null,
-    subTree: null,
-    effect: null,
-    update: null,
-    scope: new EffectScope(
-      true
-      /* detached */
-    ),
-    render: null,
-    proxy: null,
-    exposed: null,
-    exposeProxy: null,
-    withProxy: null,
-    provides: parent ? parent.provides : Object.create(appContext.provides),
-    accessCache: null,
-    renderCache: [],
-    // local resolved assets
-    components: null,
-    directives: null,
-    // resolved props and emits options
-    propsOptions: normalizePropsOptions(type, appContext),
-    emitsOptions: normalizeEmitsOptions(type, appContext),
-    // emit
-    emit: null,
-    emitted: null,
-    // props default value
-    propsDefaults: EMPTY_OBJ,
-    // inheritAttrs
-    inheritAttrs: type.inheritAttrs,
-    // state
-    ctx: EMPTY_OBJ,
-    data: EMPTY_OBJ,
-    props: EMPTY_OBJ,
-    attrs: EMPTY_OBJ,
-    slots: EMPTY_OBJ,
-    refs: EMPTY_OBJ,
-    setupState: EMPTY_OBJ,
-    setupContext: null,
-    // suspense related
-    suspense,
-    suspenseId: suspense ? suspense.pendingId : 0,
-    asyncDep: null,
-    asyncResolved: false,
-    // lifecycle hooks
-    // not using enums here because it results in computed properties
-    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.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("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
-    /*, children*/
-  } = 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(`"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(setupResult)) {
-      setupResult.then(unsetCurrentInstance, unsetCurrentInstance);
-      {
-        warn(`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(setupResult)) {
-    if (isVNode(setupResult)) {
-      warn(`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(`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(
-        `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".`
-        /* should not happen */
-      );
-    } else {
-      warn(`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(`setupContext.attrs is readonly.`);
-        return false;
-      },
-      deleteProperty() {
-        warn(`setupContext.attrs is readonly.`);
-        return false;
-      }
-    }
-  );
-}
-function createSetupContext(instance) {
-  const expose = (exposed) => {
-    {
-      if (instance.exposed) {
-        warn(`expose() should be called only once per setup().`);
-      }
-      if (exposed != null) {
-        let exposedType = typeof exposed;
-        if (exposedType === "object") {
-          if (isArray(exposed)) {
-            exposedType = "array";
-          } else if (isRef(exposed)) {
-            exposedType = "ref";
-          }
-        }
-        if (exposedType !== "object") {
-          warn(`expose() should be passed a plain object, received ${exposedType}.`);
-        }
-      }
-    }
-    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];
-      },
-      has(target, key) {
-        return key in target || key in publicPropertiesMap;
-      }
-    }));
-  }
-}
-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 = (getterOrOptions, debugOptions) => {
-  return computed$1(getterOrOptions, debugOptions, isInSSRComponentSetup);
-};
-const version = "3.2.47";
-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(instance, fn) {
-  const ctx = instance.ctx;
-  if (!ctx.__next_tick_pending && !hasComponentEffect(instance)) {
-    return nextTick$1(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
-        /* ErrorCodes.SCHEDULER */
-      );
-    } else if (_resolve) {
-      _resolve(instance.proxy);
-    }
-  });
-  return new Promise((resolve) => {
-    _resolve = resolve;
-  });
-}
-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();
-    } else {
-      flushCallbacks(instance);
-    }
-  }
-}
-function initAppConfig(appConfig) {
-  appConfig.globalProperties.$nextTick = function $nextTick(fn) {
-    return nextTick(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 = (
-      // 字节小程序 selectAllComponents 可能返回 null
-      // https://github.com/dcloudio/uni-app/issues/3954
-      ($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(instance, doSet);
-  }
-}
-function toSkip(value) {
-  if (isObject(value)) {
-    markRaw(value);
-  }
-  return value;
-}
-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 toSkip(mpInstance);
-  }
-  return null;
-}
-function setTemplateRef({ r, f }, refValue, setupState) {
-  if (isFunction(r)) {
-    r(refValue, {});
-  } else {
-    const _isString = isString(r);
-    const _isRef = isRef(r);
-    if (_isString || _isRef) {
-      if (f) {
-        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("Invalid template ref type:", ref2, `(${typeof ref2})`);
-}
-var MPType;
-(function(MPType2) {
-  MPType2["APP"] = "app";
-  MPType2["PAGE"] = "page";
-  MPType2["COMPONENT"] = "component";
-})(MPType || (MPType = {}));
-const queuePostRenderEffect = 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);
-    startMeasure(instance, `mount`);
-  }
-  {
-    startMeasure(instance, `init`);
-  }
-  setupComponent(instance);
-  {
-    endMeasure(instance, `init`);
-  }
-  {
-    if (options.parentComponent && instance.proxy) {
-      options.parentComponent.ctx.$children.push(getExposeProxy(instance) || instance.proxy);
-    }
-  }
-  setupRenderEffect(instance);
-  {
-    popWarningContext();
-    endMeasure(instance, `mount`);
-  }
-  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
-        /* we know it doesn't need it */
-      );
-    }
-  } catch (err) {
-    handleError(
-      err,
-      instance,
-      1
-      /* ErrorCodes.RENDER_FUNCTION */
-    );
-    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();
-  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 }, allowed) {
-  effect.allowRecurse = update.allowRecurse = allowed;
-}
-function setupRenderEffect(instance) {
-  const updateScopedSlots = componentUpdateScopedSlotsFn.bind(instance);
-  instance.$updateScopedSlots = () => nextTick$1(() => queueJob(updateScopedSlots));
-  const componentUpdateFn = () => {
-    if (!instance.isMounted) {
-      onBeforeUnmount(() => {
-        setRef$1(instance, true);
-      }, instance);
-      {
-        startMeasure(instance, `patch`);
-      }
-      patch(instance, renderComponentRoot(instance));
-      {
-        endMeasure(instance, `patch`);
-      }
-      {
-        devtoolsComponentAdded(instance);
-      }
-    } else {
-      const { next, bu, u } = instance;
-      {
-        pushWarningContext(next || instance.vnode);
-      }
-      toggleRecurse(instance, false);
-      updateComponentPreRender();
-      if (bu) {
-        invokeArrayFns$1(bu);
-      }
-      toggleRecurse(instance, true);
-      {
-        startMeasure(instance, `patch`);
-      }
-      patch(instance, renderComponentRoot(instance));
-      {
-        endMeasure(instance, `patch`);
-      }
-      if (u) {
-        queuePostRenderEffect(u);
-      }
-      {
-        devtoolsComponentUpdated(instance);
-      }
-      {
-        popWarningContext();
-      }
-    }
-  };
-  const effect = instance.effect = new ReactiveEffect(
-    componentUpdateFn,
-    () => queueJob(instance.update),
-    instance.scope
-    // track it in component's effect scope
-  );
-  const update = instance.update = effect.run.bind(effect);
-  update.id = instance.uid;
-  toggleRecurse(instance, true);
-  {
-    effect.onTrack = instance.rtc ? (e) => invokeArrayFns$1(instance.rtc, e) : void 0;
-    effect.onTrigger = instance.rtg ? (e) => invokeArrayFns$1(instance.rtg, e) : void 0;
-    update.ownerInstance = instance;
-  }
-  update();
-}
-function unmountComponent(instance) {
-  const { bum, scope, update, um } = instance;
-  if (bum) {
-    invokeArrayFns$1(bum);
-  }
-  scope.stop();
-  if (update) {
-    update.active = false;
-  }
-  if (um) {
-    queuePostRenderEffect(um);
-  }
-  queuePostRenderEffect(() => {
-    instance.isUnmounted = true;
-  });
-  {
-    devtoolsComponentRemoved(instance);
-  }
-}
-const oldCreateApp = createAppAPI();
-function getTarget() {
-  if (typeof window !== "undefined") {
-    return window;
-  }
-  if (typeof globalThis !== "undefined") {
-    return globalThis;
-  }
-  if (typeof global !== "undefined") {
-    return global;
-  }
-  if (typeof my !== "undefined") {
-    return my;
-  }
-}
-function createVueApp(rootComponent, rootProps = null) {
-  const target = getTarget();
-  target.__VUE__ = true;
-  {
-    setDevtoolsHook(target.__VUE_DEVTOOLS_GLOBAL_HOOK__, target);
-  }
-  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.$;
-    {
-      devtoolsInitApp(app, version);
-    }
-    instance.$app = app;
-    instance.$createComponent = createComponent2;
-    instance.$destroyComponent = destroyComponent;
-    appContext.$appInstance = instance;
-    return instance;
-  };
-  app.unmount = function unmount() {
-    warn(`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 || mpType === "component") {
-    return;
-  }
-  Object.keys(options).forEach((name) => {
-    if (isUniLifecycleHook(name, options[name], false)) {
-      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$3(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("获取当前用户信息出错,详细错误信息为:" + 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;
-  appConfig.errorHandler = invokeCreateErrorHandler(app, createErrorHandler);
-  initOptionMergeStrategies(appConfig.optionMergeStrategies);
-  const globalProperties = appConfig.globalProperties;
-  {
-    uniIdMixin(globalProperties);
-  }
-  {
-    globalProperties.$set = set$3;
-    globalProperties.$applyOptions = applyOptions$2;
-  }
-  {
-    index.invokeCreateVueAppHook(app);
-  }
-}
-const propsCaches = /* @__PURE__ */ Object.create(null);
-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];
-  }
-}
-const t = (val) => toDisplayString(val);
-function createApp$1(rootComponent, rootProps = null) {
-  rootComponent && (rootComponent.mpType = "app");
-  return createVueApp(rootComponent, rootProps).use(plugin);
-}
-const createSSRApp = createApp$1;
-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";
-  }
-  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
-  // 'onReady', // lifetimes.ready
-  // 'onPageScroll', // 影响性能,开发者手动注册
-  // 'onShareTimeline', // 右上角菜单,开发者手动注册
-  // 'onShareAppMessage' // 右上角菜单,开发者手动注册
-];
-function findHooks(vueOptions, hooks = /* @__PURE__ */ new Set()) {
-  if (vueOptions) {
-    Object.keys(vueOptions).forEach((name) => {
-      if (isUniLifecycleHook(name, 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 = isFunction(getApp) && 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 = isFunction(getApp) && getApp({
-      allowDefault: true
-    });
-    if (!app)
-      return;
-    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];
-    }
-  });
-}
-const WORKLET_RE = /_(.*)_worklet_factory_/;
-function initWorkletMethods(mpMethods, vueMethods) {
-  if (vueMethods) {
-    Object.keys(vueMethods).forEach((name) => {
-      const matches = name.match(WORKLET_RE);
-      if (matches) {
-        const workletName = matches[1];
-        mpMethods[name] = vueMethods[name];
-        mpMethods[workletName] = vueMethods[workletName];
-      }
-    });
-  }
-}
-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 = [
-  // 百度小程序,快手小程序自定义组件不支持绑定动态事件,动态dataset,故通过props传递事件信息
-  // event-opts
-  "eO",
-  // 组件 ref
-  "uR",
-  // 组件 ref-in-for
-  "uRIF",
-  // 组件 id
-  "uI",
-  // 组件类型 m: 小程序组件
-  "uT",
-  // 组件 props
-  "uP",
-  // 小程序不能直接定义 $slots 的 props,所以通过 vueSlots 转换到 $slots
-  "uS"
-];
-function initDefaultProps(options, 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
-        });
-      }
-    };
-  }
-  if (options.behaviors) {
-    if (options.behaviors.includes("wx://form-field")) {
-      if (!options.properties || !options.properties.name) {
-        properties.name = {
-          type: null,
-          value: ""
-        };
-      }
-      if (!options.properties || !options.properties.value) {
-        properties.value = {
-          type: null,
-          value: ""
-        };
-      }
-    }
-  }
-  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(mpComponentOptions), 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$1(rawProps)) {
-    Object.keys(rawProps).forEach((key) => {
-      const opts = rawProps[key];
-      if (isPlainObject$1(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$1(properties)) {
-    Object.keys(properties).forEach((name) => {
-      if (builtInProps.indexOf(name) === -1) {
-        propsData[name] = properties[name];
-      }
-    });
-  }
-  return propsData;
-}
-function initFormField(vm) {
-  const vueOptions = vm.$options;
-  if (isArray(vueOptions.behaviors) && vueOptions.behaviors.includes("uni://form-field")) {
-    vm.$watch("modelValue", () => {
-      vm.$scope && vm.$scope.setData({
-        name: vm.name,
-        value: vm.modelValue
-      });
-    }, {
-      immediate: true
-    });
-  }
-}
-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("modelValue");
-        } else {
-          vueProps.name = {
-            type: String,
-            default: ""
-          };
-          vueProps.modelValue = {
-            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,
-    // styleIsolation: 'apply-shared',
-    addGlobalClass: true,
-    pureDataPattern: /^uP$/
-  };
-  if (isArray(vueOptions.mixins)) {
-    vueOptions.mixins.forEach((item) => {
-      if (isObject(item.options)) {
-        extend(options, item.options);
-      }
-    });
-  }
-  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);
-  {
-    initWorkletMethods(mpComponentOptions.methods, vueOptions.methods);
-  }
-  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 = getAppVm().$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;
-  const newTriggerEvent = function(event, ...args) {
-    return oldTriggerEvent.apply(mpInstance, [customizeEvent(event), ...args]);
-  };
-  try {
-    mpInstance.triggerEvent = newTriggerEvent;
-  } catch (error) {
-    mpInstance._triggerEvent = newTriggerEvent;
-  }
-}
-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);
-        }
-      });
-      if (!isMiniProgramPage) {
-        initFormField(this.$vm);
-      }
-    },
-    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,
-  handleLink,
-  initLifetimes,
-  initRelation,
-  isPage,
-  mocks
-});
-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;
-}
-const createHook = (lifecycle) => (hook, target = getCurrentInstance()) => {
-  !isInSSRComponentSetup && injectHook(lifecycle, hook, target);
-};
-const onShow = /* @__PURE__ */ createHook(ON_SHOW);
-const onHide = /* @__PURE__ */ createHook(ON_HIDE);
-const onLaunch = /* @__PURE__ */ createHook(ON_LAUNCH);
-const onLoad = /* @__PURE__ */ createHook(ON_LOAD);
-var isVue2 = false;
-function set(target, key, val) {
-  if (Array.isArray(target)) {
-    target.length = Math.max(target.length, key);
-    target.splice(key, 1, val);
-    return val;
-  }
-  target[key] = val;
-  return val;
-}
-function del(target, key) {
-  if (Array.isArray(target)) {
-    target.splice(key, 1);
-    return;
-  }
-  delete target[key];
-}
-/*!
-  * pinia v2.0.33
-  * (c) 2023 Eduardo San Martin Morote
-  * @license MIT
-  */
-let activePinia;
-const setActivePinia = (pinia) => activePinia = pinia;
-const piniaSymbol = Symbol("pinia");
-function isPlainObject(o) {
-  return o && typeof o === "object" && Object.prototype.toString.call(o) === "[object Object]" && typeof o.toJSON !== "function";
-}
-var MutationType;
-(function(MutationType2) {
-  MutationType2["direct"] = "direct";
-  MutationType2["patchObject"] = "patch object";
-  MutationType2["patchFunction"] = "patch function";
-})(MutationType || (MutationType = {}));
-const IS_CLIENT = typeof window !== "undefined";
-const USE_DEVTOOLS = IS_CLIENT;
-const componentStateTypes = [];
-const getStoreType = (id) => "🍍 " + id;
-function addStoreToDevtools(app, store) {
-  if (!componentStateTypes.includes(getStoreType(store.$id))) {
-    componentStateTypes.push(getStoreType(store.$id));
-  }
-}
-function patchActionForGrouping(store, actionNames) {
-  const actions = actionNames.reduce((storeActions, actionName) => {
-    storeActions[actionName] = toRaw(store)[actionName];
-    return storeActions;
-  }, {});
-  for (const actionName in actions) {
-    store[actionName] = function() {
-      const trackedStore = new Proxy(store, {
-        get(...args) {
-          return Reflect.get(...args);
-        },
-        set(...args) {
-          return Reflect.set(...args);
-        }
-      });
-      return actions[actionName].apply(trackedStore, arguments);
-    };
-  }
-}
-function devtoolsPlugin({ app, store, options }) {
-  if (store.$id.startsWith("__hot:")) {
-    return;
-  }
-  if (options.state) {
-    store._isOptionsAPI = true;
-  }
-  if (typeof options.state === "function") {
-    patchActionForGrouping(
-      // @ts-expect-error: can cast the store...
-      store,
-      Object.keys(options.actions)
-    );
-    const originalHotUpdate = store._hotUpdate;
-    toRaw(store)._hotUpdate = function(newStore) {
-      originalHotUpdate.apply(this, arguments);
-      patchActionForGrouping(store, Object.keys(newStore._hmrPayload.actions));
-    };
-  }
-  addStoreToDevtools(
-    app,
-    // FIXME: is there a way to allow the assignment from Store<Id, S, G, A> to StoreGeneric?
-    store
-  );
-}
-function createPinia() {
-  const scope = effectScope(true);
-  const state = scope.run(() => ref({}));
-  let _p = [];
-  let toBeInstalled = [];
-  const pinia = markRaw({
-    install(app) {
-      setActivePinia(pinia);
-      {
-        pinia._a = app;
-        app.provide(piniaSymbol, pinia);
-        app.config.globalProperties.$pinia = pinia;
-        toBeInstalled.forEach((plugin2) => _p.push(plugin2));
-        toBeInstalled = [];
-      }
-    },
-    use(plugin2) {
-      if (!this._a && !isVue2) {
-        toBeInstalled.push(plugin2);
-      } else {
-        _p.push(plugin2);
-      }
-      return this;
-    },
-    _p,
-    // it's actually undefined here
-    // @ts-expect-error
-    _a: null,
-    _e: scope,
-    _s: /* @__PURE__ */ new Map(),
-    state
-  });
-  if (USE_DEVTOOLS && typeof Proxy !== "undefined") {
-    pinia.use(devtoolsPlugin);
-  }
-  return pinia;
-}
-function patchObject(newState, oldState) {
-  for (const key in oldState) {
-    const subPatch = oldState[key];
-    if (!(key in newState)) {
-      continue;
-    }
-    const targetValue = newState[key];
-    if (isPlainObject(targetValue) && isPlainObject(subPatch) && !isRef(subPatch) && !isReactive(subPatch)) {
-      newState[key] = patchObject(targetValue, subPatch);
-    } else {
-      {
-        newState[key] = subPatch;
-      }
-    }
-  }
-  return newState;
-}
-const noop = () => {
-};
-function addSubscription(subscriptions, callback, detached, onCleanup = noop) {
-  subscriptions.push(callback);
-  const removeSubscription = () => {
-    const idx = subscriptions.indexOf(callback);
-    if (idx > -1) {
-      subscriptions.splice(idx, 1);
-      onCleanup();
-    }
-  };
-  if (!detached && getCurrentScope()) {
-    onScopeDispose(removeSubscription);
-  }
-  return removeSubscription;
-}
-function triggerSubscriptions(subscriptions, ...args) {
-  subscriptions.slice().forEach((callback) => {
-    callback(...args);
-  });
-}
-function mergeReactiveObjects(target, patchToApply) {
-  if (target instanceof Map && patchToApply instanceof Map) {
-    patchToApply.forEach((value, key) => target.set(key, value));
-  }
-  if (target instanceof Set && patchToApply instanceof Set) {
-    patchToApply.forEach(target.add, target);
-  }
-  for (const key in patchToApply) {
-    if (!patchToApply.hasOwnProperty(key))
-      continue;
-    const subPatch = patchToApply[key];
-    const targetValue = target[key];
-    if (isPlainObject(targetValue) && isPlainObject(subPatch) && target.hasOwnProperty(key) && !isRef(subPatch) && !isReactive(subPatch)) {
-      target[key] = mergeReactiveObjects(targetValue, subPatch);
-    } else {
-      target[key] = subPatch;
-    }
-  }
-  return target;
-}
-const skipHydrateSymbol = Symbol("pinia:skipHydration");
-function shouldHydrate(obj) {
-  return !isPlainObject(obj) || !obj.hasOwnProperty(skipHydrateSymbol);
-}
-const { assign } = Object;
-function isComputed(o) {
-  return !!(isRef(o) && o.effect);
-}
-function createOptionsStore(id, options, pinia, hot) {
-  const { state, actions, getters } = options;
-  const initialState = pinia.state.value[id];
-  let store;
-  function setup() {
-    if (!initialState && !hot) {
-      {
-        pinia.state.value[id] = state ? state() : {};
-      }
-    }
-    const localState = hot ? (
-      // use ref() to unwrap refs inside state TODO: check if this is still necessary
-      toRefs(ref(state ? state() : {}).value)
-    ) : toRefs(pinia.state.value[id]);
-    return assign(localState, actions, Object.keys(getters || {}).reduce((computedGetters, name) => {
-      if (name in localState) {
-        console.warn(`[🍍]: A getter cannot have the same name as another state property. Rename one of them. Found with "${name}" in store "${id}".`);
-      }
-      computedGetters[name] = markRaw(computed(() => {
-        setActivePinia(pinia);
-        const store2 = pinia._s.get(id);
-        return getters[name].call(store2, store2);
-      }));
-      return computedGetters;
-    }, {}));
-  }
-  store = createSetupStore(id, setup, options, pinia, hot, true);
-  return store;
-}
-function createSetupStore($id, setup, options = {}, pinia, hot, isOptionsStore) {
-  let scope;
-  const optionsForPlugin = assign({ actions: {} }, options);
-  if (!pinia._e.active) {
-    throw new Error("Pinia destroyed");
-  }
-  const $subscribeOptions = {
-    deep: true
-    // flush: 'post',
-  };
-  {
-    $subscribeOptions.onTrigger = (event) => {
-      if (isListening) {
-        debuggerEvents = event;
-      } else if (isListening == false && !store._hotUpdating) {
-        if (Array.isArray(debuggerEvents)) {
-          debuggerEvents.push(event);
-        } else {
-          console.error("🍍 debuggerEvents should be an array. This is most likely an internal Pinia bug.");
-        }
-      }
-    };
-  }
-  let isListening;
-  let isSyncListening;
-  let subscriptions = markRaw([]);
-  let actionSubscriptions = markRaw([]);
-  let debuggerEvents;
-  const initialState = pinia.state.value[$id];
-  if (!isOptionsStore && !initialState && !hot) {
-    {
-      pinia.state.value[$id] = {};
-    }
-  }
-  const hotState = ref({});
-  let activeListener;
-  function $patch(partialStateOrMutator) {
-    let subscriptionMutation;
-    isListening = isSyncListening = false;
-    {
-      debuggerEvents = [];
-    }
-    if (typeof partialStateOrMutator === "function") {
-      partialStateOrMutator(pinia.state.value[$id]);
-      subscriptionMutation = {
-        type: MutationType.patchFunction,
-        storeId: $id,
-        events: debuggerEvents
-      };
-    } else {
-      mergeReactiveObjects(pinia.state.value[$id], partialStateOrMutator);
-      subscriptionMutation = {
-        type: MutationType.patchObject,
-        payload: partialStateOrMutator,
-        storeId: $id,
-        events: debuggerEvents
-      };
-    }
-    const myListenerId = activeListener = Symbol();
-    nextTick$1().then(() => {
-      if (activeListener === myListenerId) {
-        isListening = true;
-      }
-    });
-    isSyncListening = true;
-    triggerSubscriptions(subscriptions, subscriptionMutation, pinia.state.value[$id]);
-  }
-  const $reset = isOptionsStore ? function $reset2() {
-    const { state } = options;
-    const newState = state ? state() : {};
-    this.$patch(($state) => {
-      assign($state, newState);
-    });
-  } : (
-    /* istanbul ignore next */
-    () => {
-      throw new Error(`🍍: Store "${$id}" is built using the setup syntax and does not implement $reset().`);
-    }
-  );
-  function $dispose() {
-    scope.stop();
-    subscriptions = [];
-    actionSubscriptions = [];
-    pinia._s.delete($id);
-  }
-  function wrapAction(name, action) {
-    return function() {
-      setActivePinia(pinia);
-      const args = Array.from(arguments);
-      const afterCallbackList = [];
-      const onErrorCallbackList = [];
-      function after(callback) {
-        afterCallbackList.push(callback);
-      }
-      function onError(callback) {
-        onErrorCallbackList.push(callback);
-      }
-      triggerSubscriptions(actionSubscriptions, {
-        args,
-        name,
-        store,
-        after,
-        onError
-      });
-      let ret;
-      try {
-        ret = action.apply(this && this.$id === $id ? this : store, args);
-      } catch (error) {
-        triggerSubscriptions(onErrorCallbackList, error);
-        throw error;
-      }
-      if (ret instanceof Promise) {
-        return ret.then((value) => {
-          triggerSubscriptions(afterCallbackList, value);
-          return value;
-        }).catch((error) => {
-          triggerSubscriptions(onErrorCallbackList, error);
-          return Promise.reject(error);
-        });
-      }
-      triggerSubscriptions(afterCallbackList, ret);
-      return ret;
-    };
-  }
-  const _hmrPayload = /* @__PURE__ */ markRaw({
-    actions: {},
-    getters: {},
-    state: [],
-    hotState
-  });
-  const partialStore = {
-    _p: pinia,
-    // _s: scope,
-    $id,
-    $onAction: addSubscription.bind(null, actionSubscriptions),
-    $patch,
-    $reset,
-    $subscribe(callback, options2 = {}) {
-      const removeSubscription = addSubscription(subscriptions, callback, options2.detached, () => stopWatcher());
-      const stopWatcher = scope.run(() => watch(() => pinia.state.value[$id], (state) => {
-        if (options2.flush === "sync" ? isSyncListening : isListening) {
-          callback({
-            storeId: $id,
-            type: MutationType.direct,
-            events: debuggerEvents
-          }, state);
-        }
-      }, assign({}, $subscribeOptions, options2)));
-      return removeSubscription;
-    },
-    $dispose
-  };
-  const store = reactive(
-    assign(
-      {
-        _hmrPayload,
-        _customProperties: markRaw(/* @__PURE__ */ new Set())
-        // devtools custom properties
-      },
-      partialStore
-      // must be added later
-      // setupStore
-    )
-  );
-  pinia._s.set($id, store);
-  const setupStore = pinia._e.run(() => {
-    scope = effectScope();
-    return scope.run(() => setup());
-  });
-  for (const key in setupStore) {
-    const prop = setupStore[key];
-    if (isRef(prop) && !isComputed(prop) || isReactive(prop)) {
-      if (hot) {
-        set(hotState.value, key, toRef(setupStore, key));
-      } else if (!isOptionsStore) {
-        if (initialState && shouldHydrate(prop)) {
-          if (isRef(prop)) {
-            prop.value = initialState[key];
-          } else {
-            mergeReactiveObjects(prop, initialState[key]);
-          }
-        }
-        {
-          pinia.state.value[$id][key] = prop;
-        }
-      }
-      {
-        _hmrPayload.state.push(key);
-      }
-    } else if (typeof prop === "function") {
-      const actionValue = hot ? prop : wrapAction(key, prop);
-      {
-        setupStore[key] = actionValue;
-      }
-      {
-        _hmrPayload.actions[key] = prop;
-      }
-      optionsForPlugin.actions[key] = prop;
-    } else {
-      if (isComputed(prop)) {
-        _hmrPayload.getters[key] = isOptionsStore ? (
-          // @ts-expect-error
-          options.getters[key]
-        ) : prop;
-        if (IS_CLIENT) {
-          const getters = setupStore._getters || // @ts-expect-error: same
-          (setupStore._getters = markRaw([]));
-          getters.push(key);
-        }
-      }
-    }
-  }
-  {
-    assign(store, setupStore);
-    assign(toRaw(store), setupStore);
-  }
-  Object.defineProperty(store, "$state", {
-    get: () => hot ? hotState.value : pinia.state.value[$id],
-    set: (state) => {
-      if (hot) {
-        throw new Error("cannot set hotState");
-      }
-      $patch(($state) => {
-        assign($state, state);
-      });
-    }
-  });
-  {
-    store._hotUpdate = markRaw((newStore) => {
-      store._hotUpdating = true;
-      newStore._hmrPayload.state.forEach((stateKey) => {
-        if (stateKey in store.$state) {
-          const newStateTarget = newStore.$state[stateKey];
-          const oldStateSource = store.$state[stateKey];
-          if (typeof newStateTarget === "object" && isPlainObject(newStateTarget) && isPlainObject(oldStateSource)) {
-            patchObject(newStateTarget, oldStateSource);
-          } else {
-            newStore.$state[stateKey] = oldStateSource;
-          }
-        }
-        set(store, stateKey, toRef(newStore.$state, stateKey));
-      });
-      Object.keys(store.$state).forEach((stateKey) => {
-        if (!(stateKey in newStore.$state)) {
-          del(store, stateKey);
-        }
-      });
-      isListening = false;
-      isSyncListening = false;
-      pinia.state.value[$id] = toRef(newStore._hmrPayload, "hotState");
-      isSyncListening = true;
-      nextTick$1().then(() => {
-        isListening = true;
-      });
-      for (const actionName in newStore._hmrPayload.actions) {
-        const action = newStore[actionName];
-        set(store, actionName, wrapAction(actionName, action));
-      }
-      for (const getterName in newStore._hmrPayload.getters) {
-        const getter = newStore._hmrPayload.getters[getterName];
-        const getterValue = isOptionsStore ? (
-          // special handling of options api
-          computed(() => {
-            setActivePinia(pinia);
-            return getter.call(store, store);
-          })
-        ) : getter;
-        set(store, getterName, getterValue);
-      }
-      Object.keys(store._hmrPayload.getters).forEach((key) => {
-        if (!(key in newStore._hmrPayload.getters)) {
-          del(store, key);
-        }
-      });
-      Object.keys(store._hmrPayload.actions).forEach((key) => {
-        if (!(key in newStore._hmrPayload.actions)) {
-          del(store, key);
-        }
-      });
-      store._hmrPayload = newStore._hmrPayload;
-      store._getters = newStore._getters;
-      store._hotUpdating = false;
-    });
-  }
-  if (USE_DEVTOOLS) {
-    const nonEnumerable = {
-      writable: true,
-      configurable: true,
-      // avoid warning on devtools trying to display this property
-      enumerable: false
-    };
-    ["_p", "_hmrPayload", "_getters", "_customProperties"].forEach((p) => {
-      Object.defineProperty(store, p, assign({ value: store[p] }, nonEnumerable));
-    });
-  }
-  pinia._p.forEach((extender) => {
-    if (USE_DEVTOOLS) {
-      const extensions = scope.run(() => extender({
-        store,
-        app: pinia._a,
-        pinia,
-        options: optionsForPlugin
-      }));
-      Object.keys(extensions || {}).forEach((key) => store._customProperties.add(key));
-      assign(store, extensions);
-    } else {
-      assign(store, scope.run(() => extender({
-        store,
-        app: pinia._a,
-        pinia,
-        options: optionsForPlugin
-      })));
-    }
-  });
-  if (store.$state && typeof store.$state === "object" && typeof store.$state.constructor === "function" && !store.$state.constructor.toString().includes("[native code]")) {
-    console.warn(`[🍍]: The "state" must be a plain object. It cannot be
-	state: () => new MyClass()
-Found in store "${store.$id}".`);
-  }
-  if (initialState && isOptionsStore && options.hydrate) {
-    options.hydrate(store.$state, initialState);
-  }
-  isListening = true;
-  isSyncListening = true;
-  return store;
-}
-function defineStore(idOrOptions, setup, setupOptions) {
-  let id;
-  let options;
-  const isSetupStore = typeof setup === "function";
-  if (typeof idOrOptions === "string") {
-    id = idOrOptions;
-    options = isSetupStore ? setupOptions : setup;
-  } else {
-    options = idOrOptions;
-    id = idOrOptions.id;
-  }
-  function useStore(pinia, hot) {
-    const currentInstance2 = getCurrentInstance();
-    pinia = // in test mode, ignore the argument provided as we can always retrieve a
-    // pinia instance with getActivePinia()
-    pinia || currentInstance2 && inject(piniaSymbol, null);
-    if (pinia)
-      setActivePinia(pinia);
-    if (!activePinia) {
-      throw new Error(`[🍍]: getActivePinia was called with no active Pinia. Did you forget to install pinia?
-	const pinia = createPinia()
-	app.use(pinia)
-This will fail in production.`);
-    }
-    pinia = activePinia;
-    if (!pinia._s.has(id)) {
-      if (isSetupStore) {
-        createSetupStore(id, setup, options, pinia);
-      } else {
-        createOptionsStore(id, options, pinia);
-      }
-      {
-        useStore._pinia = pinia;
-      }
-    }
-    const store = pinia._s.get(id);
-    if (hot) {
-      const hotId = "__hot:" + id;
-      const newStore = isSetupStore ? createSetupStore(hotId, setup, options, pinia, true) : createOptionsStore(hotId, assign({}, options), pinia, true);
-      hot._hotUpdate(newStore);
-      delete pinia.state.value[hotId];
-      pinia._s.delete(hotId);
-    }
-    if (IS_CLIENT && currentInstance2 && currentInstance2.proxy && // avoid adding stores that are just built for hot module replacement
-    !hot) {
-      const vm = currentInstance2.proxy;
-      const cache = "_pStores" in vm ? vm._pStores : vm._pStores = {};
-      cache[id] = store;
-    }
-    return store;
-  }
-  useStore.$id = id;
-  return useStore;
-}
-exports._export_sfc = _export_sfc;
-exports.createPinia = createPinia;
-exports.createSSRApp = createSSRApp;
-exports.defineStore = defineStore;
-exports.index = index;
-exports.onHide = onHide;
-exports.onLaunch = onLaunch;
-exports.onLoad = onLoad;
-exports.onShow = onShow;
-exports.t = t;
-exports.unref = unref;

+ 0 - 3
unpackage/dist/dev/mp-weixin/config/api.js

@@ -1,3 +0,0 @@
-"use strict";
-const common_vendor = require("../common/vendor.js");
-common_vendor.index.$u.http;

+ 0 - 58
unpackage/dist/dev/mp-weixin/config/hooks.js

@@ -1,58 +0,0 @@
-"use strict";
-require("../common/vendor.js");
-require("./api.js");
-require("../store/index.js");
-function getDate(time = Number(/* @__PURE__ */ new Date()), isGetText = true) {
-  const _time = time.toString().length > 10 ? time : time * 1e3;
-  var date = new Date(_time);
-  var Y = date.getFullYear();
-  var M = date.getMonth() + 1 < 10 ? "0" + (date.getMonth() + 1) : date.getMonth() + 1;
-  var D = date.getDate() < 10 ? "0" + date.getDate() : date.getDate();
-  var h = date.getHours() < 10 ? "0" + date.getHours() : date.getHours();
-  var m = date.getMinutes() < 10 ? "0" + date.getMinutes() : date.getMinutes();
-  var s = date.getSeconds() < 10 ? "0" + date.getSeconds() : date.getSeconds();
-  let text = "";
-  if (isGetText) {
-    let nd = getDate(void 0, false);
-    if (Y == nd.Y) {
-      if (M == nd.M) {
-        if (D == nd.D) {
-          if (h == nd.h) {
-            let mc = nd.m - m;
-            if (mc > 0) {
-              text = `${mc}分钟前`;
-            } else {
-              text = `刚刚`;
-            }
-          } else {
-            text = `${nd.h - h}小时前`;
-          }
-        } else {
-          if (D == nd.D - 1) {
-            text = `昨天 ${h}:${m}`;
-          } else {
-            text = `${Y}年${M}月${D}日 ${h}:${m}`;
-          }
-        }
-      } else {
-        text = `${Y}年${M}月${D}日 ${h}:${m}`;
-      }
-    } else {
-      text = `${Y}年${M}月${D}日 ${h}:${m}`;
-    }
-  }
-  let obj = {
-    date: `${Y}年${M}月${D}日`,
-    time: `${h}时${m}分${s}秒`,
-    Y,
-    M,
-    D,
-    h,
-    m,
-    s,
-    text
-    // 这里返回的是类似于 1分钟前 这种文字
-  };
-  return obj;
-}
-exports.getDate = getDate;

+ 0 - 46
unpackage/dist/dev/mp-weixin/config/request.js

@@ -1,46 +0,0 @@
-"use strict";
-const common_vendor = require("../common/vendor.js");
-const store_index = require("../store/index.js");
-function initRequest() {
-  console.log("初始化了 http 请求代码");
-  common_vendor.index.$u.http.setConfig((config) => {
-    config.baseURL = `http://tf.hqzf100.com/dev-api/`;
-    config.custom.toast = true;
-    return config;
-  });
-  common_vendor.index.$u.http.interceptors.request.use((config) => {
-    config.data = config.data || {};
-    let token = store_index.store.token;
-    config.header.Authorization = token ? `Bearer ${token}` : "";
-    return config;
-  }, (config) => {
-    return Promise.reject(config);
-  });
-  common_vendor.index.$u.http.interceptors.response.use((response) => {
-    var _a;
-    const data = response.data;
-    const custom = (_a = response.config) == null ? void 0 : _a.custom;
-    if (data.code !== 200) {
-      if (data.code === 401) {
-        common_vendor.index.$u.toast(data.msg || "身份认证失败,请先登录");
-        store_index.store.setToken("");
-        setTimeout(() => {
-          common_vendor.index.$u.route({
-            type: "reLaunch",
-            url: "/pages/login/login"
-            // 跳转到登录页
-          });
-        }, 1e3);
-      } else {
-        if (custom.toast !== false) {
-          common_vendor.index.$u.toast(data.msg);
-        }
-        return data;
-      }
-    }
-    return data;
-  }, (response) => {
-    return Promise.reject(response);
-  });
-}
-exports.initRequest = initRequest;

+ 0 - 33
unpackage/dist/dev/mp-weixin/config/share.js

@@ -1,33 +0,0 @@
-"use strict";
-const share = {
-  data() {
-    return {
-      // 默认的全局分享内容
-      share: {
-        title: "标题",
-        path: "/pages/home/home",
-        // 这里是分享的页面
-        imageUrl: ""
-        // 这里是分析的图片,如果不写则默认截取当前分享页为分享图片
-      }
-    };
-  },
-  // 定义全局分享
-  // 1.发送给朋友
-  onShareAppMessage(res) {
-    return {
-      title: this.share.title,
-      path: this.share.path,
-      imageUrl: this.share.imageUrl
-    };
-  },
-  //2.分享到朋友圈
-  onShareTimeline(res) {
-    return {
-      title: this.share.title,
-      path: this.share.path,
-      imageUrl: this.share.imageUrl
-    };
-  }
-};
-exports.share = share;

+ 0 - 24
unpackage/dist/dev/mp-weixin/pages/home/home.js

@@ -1,24 +0,0 @@
-"use strict";
-const common_vendor = require("../../common/vendor.js");
-const store_index = require("../../store/index.js");
-const config_hooks = require("../../config/hooks.js");
-require("../../store/uses.js");
-require("../../config/api.js");
-const _sfc_main = {
-  __name: "home",
-  setup(__props) {
-    common_vendor.onLoad((args) => {
-      console.log("首页收到的参数对象", args);
-      if (!store_index.store.token) {
-        console.log("没有读取到用户的token,用户还没有登录", store_index.store.token);
-      }
-    });
-    return (_ctx, _cache) => {
-      return {
-        a: common_vendor.t(common_vendor.unref(config_hooks.getDate)().date)
-      };
-    };
-  }
-};
-const MiniProgramPage = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__scopeId", "data-v-07e72d3c"], ["__file", "F:/lty/uniapp-vue3-template/pages/home/home.vue"]]);
-wx.createPage(MiniProgramPage);

+ 0 - 4
unpackage/dist/dev/mp-weixin/pages/home/home.json

@@ -1,4 +0,0 @@
-{
-  "navigationBarTitleText": "首页",
-  "usingComponents": {}
-}

+ 0 - 1
unpackage/dist/dev/mp-weixin/pages/home/home.wxml

@@ -1 +0,0 @@
-<view class="page data-v-07e72d3c"> 这是首页:{{a}}</view>

+ 0 - 30
unpackage/dist/dev/mp-weixin/pages/home/home.wxss

@@ -1,30 +0,0 @@
-/**
- * 这里是uni-app内置的常用样式变量
- *
- * uni-app 官方扩展插件及插件市场(https://ext.dcloud.net.cn)上很多三方插件均使用了这些样式变量
- * 如果你是插件开发者,建议你使用scss预处理,并在插件代码中直接使用这些变量(无需 import 这个文件),方便用户通过搭积木的方式开发整体风格一致的App
- *
- */
-/**
- * 如果你是App开发者(插件使用者),你可以通过修改这些变量来定制自己的插件主题,实现自定义主题功能
- *
- * 如果你的项目同样使用了scss预处理,你也可以直接在你的 scss 代码中使用如下变量,同时无需 import 这个文件
- */
-/* 颜色变量 */
-/* 行为相关颜色 */
-/* 文字基本颜色 */
-/* 背景颜色 */
-/* 边框颜色 */
-/* 尺寸变量 */
-/* 文字尺寸 */
-/* 图片尺寸 */
-/* Border Radius */
-/* 水平间距 */
-/* 垂直间距 */
-/* 透明度 */
-/* 文章场景相关 */
-.page.data-v-07e72d3c {
-  width: 750rpx;
-  min-height: 100vh;
-  background-color: #fefefe;
-}

+ 0 - 17
unpackage/dist/dev/mp-weixin/pages/my/my.js

@@ -1,17 +0,0 @@
-"use strict";
-const common_vendor = require("../../common/vendor.js");
-const store_index = require("../../store/index.js");
-require("../../store/uses.js");
-const _sfc_main = {
-  __name: "my",
-  setup(__props) {
-    console.log("用户信息", store_index.store.userInfo);
-    common_vendor.onLoad(() => {
-    });
-    return (_ctx, _cache) => {
-      return {};
-    };
-  }
-};
-const MiniProgramPage = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__file", "F:/lty/uniapp-vue3-template/pages/my/my.vue"]]);
-wx.createPage(MiniProgramPage);

+ 0 - 4
unpackage/dist/dev/mp-weixin/pages/my/my.json

@@ -1,4 +0,0 @@
-{
-  "navigationBarTitleText": "个人中心",
-  "usingComponents": {}
-}

+ 0 - 1
unpackage/dist/dev/mp-weixin/pages/my/my.wxml

@@ -1 +0,0 @@
-<view class="page">个人中心</view>

+ 0 - 0
unpackage/dist/dev/mp-weixin/pages/my/my.wxss


+ 0 - 148
unpackage/dist/dev/mp-weixin/static/css/mystyle.css

@@ -1,148 +0,0 @@
-.w100 {
-	width: 100%!important;
-}
-.h100 {
-	height: 100%!important;
-}
-
-/* 定位 */
-.pos-re {
-	position: relative;
-}
-.pos-ab {
-	position: absolute;
-}
-
-.box-s {
-	box-sizing: border-box;
-}
-.flex {
-	display: flex;
-}
-.flex-1 {
-	flex: 1;
-}
-
-.flex-a {
-	display: flex;
-	align-items: center;
-}
-
-.flex-a-s {
-	align-items: flex-start;
-}
-.flex-a-c {
-	align-items: center;
-}
-.flex-a-e {
-	align-items: flex-end;
-}
-
-.flex-c {
-	display: flex;
-	align-items: center;
-	justify-content: center;
-}
-
-.flex-d {
-	display: flex;
-	flex-direction: column;
-}
-.flex-w {
-	display: flex;
-	flex-wrap: wrap;
-}
-
-.flex-j-a {
-	justify-content: space-around;
-}
-
-.flex-j-c {
-	justify-content: center;
-}
-
-.flex-j-b {
-	justify-content: space-between;
-}
-
-/* 文本仅显示 1 行 */
-.line-1 {
-	width: 100%;
-	white-space: nowrap;
-	text-overflow: ellipsis;
-	overflow: hidden;
-	word-break: break-all;
-}
-
-/* 文本仅显示 2 行 */
-.line-2 {
-	text-overflow: -o-ellipsis-lastline;
-	overflow: hidden;
-	text-overflow: ellipsis;
-	display: -webkit-box;
-	-webkit-line-clamp: 2;
-	line-clamp: 2;
-	-webkit-box-orient: vertical;
-}
-
-.m-2 {
-	margin: 20rpx;
-}
-.m-l-1 {
-	margin-left: 10rpx;
-}
-.m-l-2 {
-	margin-left: 20rpx;
-}
-.m-l-3 {
-	margin-left: 30rpx;
-}
-.m-r-1 {
-	margin-right: 10rpx;
-}
-.m-r-2 {
-	margin-right: 20rpx;
-}
-.m-r-3 {
-	margin-right: 30rpx;
-}
-.m-t-0 {
-	margin-top: 0;
-}
-.m-t-1 {
-	margin-top: 10rpx;
-}
-.m-t-2 {
-	margin-top: 20rpx;
-}
-.m-t-3 {
-	margin-top: 30rpx;
-}
-.m-b-2 {
-	margin-bottom: 20rpx;
-}
-.p-2 {
-	padding: 20rpx;
-}
-.p-l-2 {
-	padding-left: 20rpx;
-}
-.p-r-2 {
-	padding-right: 20rpx;
-}
-.p-t-2 {
-	padding-top: 20rpx;
-}
-.p-b-2 {
-	padding-bottom: 20rpx;
-}
-
-.text-l {
-	text-align: left;
-}
-.text-c {
-	text-align: center;
-}
-.text-r {
-	text-align: right;
-}

BIN
unpackage/dist/dev/mp-weixin/static/imgs/home-a.png


BIN
unpackage/dist/dev/mp-weixin/static/imgs/home.png


BIN
unpackage/dist/dev/mp-weixin/static/imgs/my-a.png


BIN
unpackage/dist/dev/mp-weixin/static/imgs/my.png


+ 0 - 6
unpackage/dist/dev/mp-weixin/store/index.js

@@ -1,6 +0,0 @@
-"use strict";
-const store_uses = require("./uses.js");
-const common_vendor = require("../common/vendor.js");
-const pinia = common_vendor.createPinia();
-const store = store_uses.useStore(pinia);
-exports.store = store;

+ 0 - 34
unpackage/dist/dev/mp-weixin/store/uses.js

@@ -1,34 +0,0 @@
-"use strict";
-const common_vendor = require("../common/vendor.js");
-const useStore = common_vendor.defineStore("user", {
-  state: () => ({
-    userInfo: {},
-    // 用户信息
-    token: "",
-    // uploadUrl: 'http://192.168.1.3:8080/ai-file/upload/oss', // 上传资源的服务器网址
-    uploadUrl: "https://gc.sdzcq.com/prod-api/ai-file/upload/oss"
-    // 上传资源的服务器网址
-  }),
-  getters: {},
-  actions: {
-    setUserInfo(data) {
-      if (data.userId) {
-        console.log("更新全局的用户信息-也更新本地存储", data);
-        this.userInfo = data;
-        common_vendor.index.setStorageSync("userInfo", JSON.stringify(data));
-      } else {
-        common_vendor.index.removeStorageSync("userInfo");
-      }
-    },
-    setToken(token) {
-      if (token) {
-        console.log("更新全局的 token -也更新本地存储", token);
-        this.token = token;
-        common_vendor.index.setStorageSync("token", token);
-      } else {
-        common_vendor.index.removeStorageSync("token");
-      }
-    }
-  }
-});
-exports.useStore = useStore;

+ 0 - 51
unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/index.js

@@ -1,51 +0,0 @@
-"use strict";
-const common_vendor = require("../../common/vendor.js");
-const uni_modules_uviewPlus_libs_mixin_mixin = require("./libs/mixin/mixin.js");
-const uni_modules_uviewPlus_libs_mixin_mpMixin = require("./libs/mixin/mpMixin.js");
-const uni_modules_uviewPlus_libs_luchRequest_core_Request = require("./libs/luch-request/core/Request.js");
-const uni_modules_uviewPlus_libs_util_route = require("./libs/util/route.js");
-const uni_modules_uviewPlus_libs_function_colorGradient = require("./libs/function/colorGradient.js");
-const uni_modules_uviewPlus_libs_function_test = require("./libs/function/test.js");
-const uni_modules_uviewPlus_libs_function_debounce = require("./libs/function/debounce.js");
-const uni_modules_uviewPlus_libs_function_throttle = require("./libs/function/throttle.js");
-const uni_modules_uviewPlus_libs_function_index = require("./libs/function/index.js");
-const uni_modules_uviewPlus_libs_config_config = require("./libs/config/config.js");
-const uni_modules_uviewPlus_libs_config_props = require("./libs/config/props.js");
-const uni_modules_uviewPlus_libs_config_zIndex = require("./libs/config/zIndex.js");
-const uni_modules_uviewPlus_libs_config_color = require("./libs/config/color.js");
-const uni_modules_uviewPlus_libs_function_platform = require("./libs/function/platform.js");
-const $u = {
-  route: uni_modules_uviewPlus_libs_util_route.route,
-  date: uni_modules_uviewPlus_libs_function_index.index.timeFormat,
-  // 另名date
-  colorGradient: uni_modules_uviewPlus_libs_function_colorGradient.colorGradient.colorGradient,
-  hexToRgb: uni_modules_uviewPlus_libs_function_colorGradient.colorGradient.hexToRgb,
-  rgbToHex: uni_modules_uviewPlus_libs_function_colorGradient.colorGradient.rgbToHex,
-  colorToRgba: uni_modules_uviewPlus_libs_function_colorGradient.colorGradient.colorToRgba,
-  test: uni_modules_uviewPlus_libs_function_test.test,
-  type: ["primary", "success", "error", "warning", "info"],
-  http: new uni_modules_uviewPlus_libs_luchRequest_core_Request.Request(),
-  config: uni_modules_uviewPlus_libs_config_config.config,
-  // uView配置信息相关,比如版本号
-  zIndex: uni_modules_uviewPlus_libs_config_zIndex.zIndex,
-  debounce: uni_modules_uviewPlus_libs_function_debounce.debounce,
-  throttle: uni_modules_uviewPlus_libs_function_throttle.throttle,
-  mixin: uni_modules_uviewPlus_libs_mixin_mixin.mixin,
-  mpMixin: uni_modules_uviewPlus_libs_mixin_mpMixin.mpMixin,
-  props: uni_modules_uviewPlus_libs_config_props.props,
-  ...uni_modules_uviewPlus_libs_function_index.index,
-  color: uni_modules_uviewPlus_libs_config_color.color,
-  platform: uni_modules_uviewPlus_libs_function_platform.platform
-};
-common_vendor.index.$u = $u;
-const install = (Vue) => {
-  Vue.config.globalProperties.$u = $u;
-  Vue.config.globalProperties.$nextTick = (cb) => {
-    cb();
-  };
-  Vue.mixin(uni_modules_uviewPlus_libs_mixin_mixin.mixin);
-};
-const uviewPlus = {
-  install
-};
-exports.uviewPlus = uviewPlus;

+ 0 - 15
unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/color.js

@@ -1,15 +0,0 @@
-"use strict";
-const color = {
-  primary: "#3c9cff",
-  info: "#909399",
-  default: "#909399",
-  warning: "#f9ae3d",
-  error: "#f56c6c",
-  success: "#5ac725",
-  mainColor: "#303133",
-  contentColor: "#606266",
-  tipsColor: "#909399",
-  lightColor: "#c0c4cc",
-  borderColor: "#e4e7ed"
-};
-exports.color = color;

+ 0 - 35
unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/config.js

@@ -1,35 +0,0 @@
-"use strict";
-const version = "3";
-{
-  console.log(`
- %c uview-plus V${version} %c https://ijry.github.io/uview-plus/ 
-
-`, "color: #ffffff; background: #3c9cff; padding:5px 0;", "color: #3c9cff;background: #ffffff; padding:5px 0;");
-}
-const config = {
-  v: version,
-  version,
-  // 主题名称
-  type: [
-    "primary",
-    "success",
-    "info",
-    "error",
-    "warning"
-  ],
-  // 颜色部分,本来可以通过scss的:export导出供js使用,但是奈何nvue不支持
-  color: {
-    "u-primary": "#2979ff",
-    "u-warning": "#ff9900",
-    "u-success": "#19be6b",
-    "u-error": "#fa3534",
-    "u-info": "#909399",
-    "u-main-color": "#303133",
-    "u-content-color": "#606266",
-    "u-tips-color": "#909399",
-    "u-light-color": "#c0c4cc"
-  },
-  // 默认单位,可以通过配置为rpx,那么在用于传入组件大小参数为数值时,就默认为rpx
-  unit: "px"
-};
-exports.config = config;

+ 0 - 183
unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props.js

@@ -1,183 +0,0 @@
-"use strict";
-require("./config.js");
-const uni_modules_uviewPlus_libs_config_props_actionSheet = require("./props/actionSheet.js");
-const uni_modules_uviewPlus_libs_config_props_album = require("./props/album.js");
-const uni_modules_uviewPlus_libs_config_props_alert = require("./props/alert.js");
-const uni_modules_uviewPlus_libs_config_props_avatar = require("./props/avatar.js");
-const uni_modules_uviewPlus_libs_config_props_avatarGroup = require("./props/avatarGroup.js");
-const uni_modules_uviewPlus_libs_config_props_backtop = require("./props/backtop.js");
-const uni_modules_uviewPlus_libs_config_props_badge = require("./props/badge.js");
-const uni_modules_uviewPlus_libs_config_props_button = require("./props/button.js");
-const uni_modules_uviewPlus_libs_config_props_calendar = require("./props/calendar.js");
-const uni_modules_uviewPlus_libs_config_props_carKeyboard = require("./props/carKeyboard.js");
-const uni_modules_uviewPlus_libs_config_props_cell = require("./props/cell.js");
-const uni_modules_uviewPlus_libs_config_props_cellGroup = require("./props/cellGroup.js");
-const uni_modules_uviewPlus_libs_config_props_checkbox = require("./props/checkbox.js");
-const uni_modules_uviewPlus_libs_config_props_checkboxGroup = require("./props/checkboxGroup.js");
-const uni_modules_uviewPlus_libs_config_props_circleProgress = require("./props/circleProgress.js");
-const uni_modules_uviewPlus_libs_config_props_code = require("./props/code.js");
-const uni_modules_uviewPlus_libs_config_props_codeInput = require("./props/codeInput.js");
-const uni_modules_uviewPlus_libs_config_props_col = require("./props/col.js");
-const uni_modules_uviewPlus_libs_config_props_collapse = require("./props/collapse.js");
-const uni_modules_uviewPlus_libs_config_props_collapseItem = require("./props/collapseItem.js");
-const uni_modules_uviewPlus_libs_config_props_columnNotice = require("./props/columnNotice.js");
-const uni_modules_uviewPlus_libs_config_props_countDown = require("./props/countDown.js");
-const uni_modules_uviewPlus_libs_config_props_countTo = require("./props/countTo.js");
-const uni_modules_uviewPlus_libs_config_props_datetimePicker = require("./props/datetimePicker.js");
-const uni_modules_uviewPlus_libs_config_props_divider = require("./props/divider.js");
-const uni_modules_uviewPlus_libs_config_props_empty = require("./props/empty.js");
-const uni_modules_uviewPlus_libs_config_props_form = require("./props/form.js");
-const uni_modules_uviewPlus_libs_config_props_formItem = require("./props/formItem.js");
-const uni_modules_uviewPlus_libs_config_props_gap = require("./props/gap.js");
-const uni_modules_uviewPlus_libs_config_props_grid = require("./props/grid.js");
-const uni_modules_uviewPlus_libs_config_props_gridItem = require("./props/gridItem.js");
-const uni_modules_uviewPlus_libs_config_props_icon = require("./props/icon.js");
-const uni_modules_uviewPlus_libs_config_props_image = require("./props/image.js");
-const uni_modules_uviewPlus_libs_config_props_indexAnchor = require("./props/indexAnchor.js");
-const uni_modules_uviewPlus_libs_config_props_indexList = require("./props/indexList.js");
-const uni_modules_uviewPlus_libs_config_props_input = require("./props/input.js");
-const uni_modules_uviewPlus_libs_config_props_keyboard = require("./props/keyboard.js");
-const uni_modules_uviewPlus_libs_config_props_line = require("./props/line.js");
-const uni_modules_uviewPlus_libs_config_props_lineProgress = require("./props/lineProgress.js");
-const uni_modules_uviewPlus_libs_config_props_link = require("./props/link.js");
-const uni_modules_uviewPlus_libs_config_props_list = require("./props/list.js");
-const uni_modules_uviewPlus_libs_config_props_listItem = require("./props/listItem.js");
-const uni_modules_uviewPlus_libs_config_props_loadingIcon = require("./props/loadingIcon.js");
-const uni_modules_uviewPlus_libs_config_props_loadingPage = require("./props/loadingPage.js");
-const uni_modules_uviewPlus_libs_config_props_loadmore = require("./props/loadmore.js");
-const uni_modules_uviewPlus_libs_config_props_modal = require("./props/modal.js");
-const uni_modules_uviewPlus_libs_config_props_navbar = require("./props/navbar.js");
-const uni_modules_uviewPlus_libs_config_props_noNetwork = require("./props/noNetwork.js");
-const uni_modules_uviewPlus_libs_config_props_noticeBar = require("./props/noticeBar.js");
-const uni_modules_uviewPlus_libs_config_props_notify = require("./props/notify.js");
-const uni_modules_uviewPlus_libs_config_props_numberBox = require("./props/numberBox.js");
-const uni_modules_uviewPlus_libs_config_props_numberKeyboard = require("./props/numberKeyboard.js");
-const uni_modules_uviewPlus_libs_config_props_overlay = require("./props/overlay.js");
-const uni_modules_uviewPlus_libs_config_props_parse = require("./props/parse.js");
-const uni_modules_uviewPlus_libs_config_props_picker = require("./props/picker.js");
-const uni_modules_uviewPlus_libs_config_props_popup = require("./props/popup.js");
-const uni_modules_uviewPlus_libs_config_props_radio = require("./props/radio.js");
-const uni_modules_uviewPlus_libs_config_props_radioGroup = require("./props/radioGroup.js");
-const uni_modules_uviewPlus_libs_config_props_rate = require("./props/rate.js");
-const uni_modules_uviewPlus_libs_config_props_readMore = require("./props/readMore.js");
-const uni_modules_uviewPlus_libs_config_props_row = require("./props/row.js");
-const uni_modules_uviewPlus_libs_config_props_rowNotice = require("./props/rowNotice.js");
-const uni_modules_uviewPlus_libs_config_props_scrollList = require("./props/scrollList.js");
-const uni_modules_uviewPlus_libs_config_props_search = require("./props/search.js");
-const uni_modules_uviewPlus_libs_config_props_section = require("./props/section.js");
-const uni_modules_uviewPlus_libs_config_props_skeleton = require("./props/skeleton.js");
-const uni_modules_uviewPlus_libs_config_props_slider = require("./props/slider.js");
-const uni_modules_uviewPlus_libs_config_props_statusBar = require("./props/statusBar.js");
-const uni_modules_uviewPlus_libs_config_props_steps = require("./props/steps.js");
-const uni_modules_uviewPlus_libs_config_props_stepsItem = require("./props/stepsItem.js");
-const uni_modules_uviewPlus_libs_config_props_sticky = require("./props/sticky.js");
-const uni_modules_uviewPlus_libs_config_props_subsection = require("./props/subsection.js");
-const uni_modules_uviewPlus_libs_config_props_swipeAction = require("./props/swipeAction.js");
-const uni_modules_uviewPlus_libs_config_props_swipeActionItem = require("./props/swipeActionItem.js");
-const uni_modules_uviewPlus_libs_config_props_swiper = require("./props/swiper.js");
-const uni_modules_uviewPlus_libs_config_props_swipterIndicator = require("./props/swipterIndicator.js");
-const uni_modules_uviewPlus_libs_config_props_switch = require("./props/switch.js");
-const uni_modules_uviewPlus_libs_config_props_tabbar = require("./props/tabbar.js");
-const uni_modules_uviewPlus_libs_config_props_tabbarItem = require("./props/tabbarItem.js");
-const uni_modules_uviewPlus_libs_config_props_tabs = require("./props/tabs.js");
-const uni_modules_uviewPlus_libs_config_props_tag = require("./props/tag.js");
-const uni_modules_uviewPlus_libs_config_props_text = require("./props/text.js");
-const uni_modules_uviewPlus_libs_config_props_textarea = require("./props/textarea.js");
-const uni_modules_uviewPlus_libs_config_props_toast = require("./props/toast.js");
-const uni_modules_uviewPlus_libs_config_props_toolbar = require("./props/toolbar.js");
-const uni_modules_uviewPlus_libs_config_props_tooltip = require("./props/tooltip.js");
-const uni_modules_uviewPlus_libs_config_props_transition = require("./props/transition.js");
-const uni_modules_uviewPlus_libs_config_props_upload = require("./props/upload.js");
-const uni_modules_uviewPlus_libs_config_props_drawer = require("./props/drawer.js");
-const props = {
-  ...uni_modules_uviewPlus_libs_config_props_actionSheet.ActionSheet,
-  ...uni_modules_uviewPlus_libs_config_props_album.Album,
-  ...uni_modules_uviewPlus_libs_config_props_alert.Alert,
-  ...uni_modules_uviewPlus_libs_config_props_avatar.Avatar,
-  ...uni_modules_uviewPlus_libs_config_props_avatarGroup.AvatarGroup,
-  ...uni_modules_uviewPlus_libs_config_props_backtop.Backtop,
-  ...uni_modules_uviewPlus_libs_config_props_badge.Badge,
-  ...uni_modules_uviewPlus_libs_config_props_button.Button,
-  ...uni_modules_uviewPlus_libs_config_props_calendar.Calendar,
-  ...uni_modules_uviewPlus_libs_config_props_carKeyboard.CarKeyboard,
-  ...uni_modules_uviewPlus_libs_config_props_cell.Cell,
-  ...uni_modules_uviewPlus_libs_config_props_cellGroup.CellGroup,
-  ...uni_modules_uviewPlus_libs_config_props_checkbox.Checkbox,
-  ...uni_modules_uviewPlus_libs_config_props_checkboxGroup.CheckboxGroup,
-  ...uni_modules_uviewPlus_libs_config_props_circleProgress.CircleProgress,
-  ...uni_modules_uviewPlus_libs_config_props_code.Code,
-  ...uni_modules_uviewPlus_libs_config_props_codeInput.CodeInput,
-  ...uni_modules_uviewPlus_libs_config_props_col.Col,
-  ...uni_modules_uviewPlus_libs_config_props_collapse.Collapse,
-  ...uni_modules_uviewPlus_libs_config_props_collapseItem.CollapseItem,
-  ...uni_modules_uviewPlus_libs_config_props_columnNotice.ColumnNotice,
-  ...uni_modules_uviewPlus_libs_config_props_countDown.CountDown,
-  ...uni_modules_uviewPlus_libs_config_props_countTo.CountTo,
-  ...uni_modules_uviewPlus_libs_config_props_datetimePicker.DatetimePicker,
-  ...uni_modules_uviewPlus_libs_config_props_divider.Divider,
-  ...uni_modules_uviewPlus_libs_config_props_empty.Empty,
-  ...uni_modules_uviewPlus_libs_config_props_form.Form,
-  ...uni_modules_uviewPlus_libs_config_props_formItem.GormItem,
-  ...uni_modules_uviewPlus_libs_config_props_gap.Gap,
-  ...uni_modules_uviewPlus_libs_config_props_grid.Grid,
-  ...uni_modules_uviewPlus_libs_config_props_gridItem.GridItem,
-  ...uni_modules_uviewPlus_libs_config_props_icon.Icon,
-  ...uni_modules_uviewPlus_libs_config_props_image.Image,
-  ...uni_modules_uviewPlus_libs_config_props_indexAnchor.IndexAnchor,
-  ...uni_modules_uviewPlus_libs_config_props_indexList.IndexList,
-  ...uni_modules_uviewPlus_libs_config_props_input.Input,
-  ...uni_modules_uviewPlus_libs_config_props_keyboard.Keyboard,
-  ...uni_modules_uviewPlus_libs_config_props_line.Line,
-  ...uni_modules_uviewPlus_libs_config_props_lineProgress.LineProgress,
-  ...uni_modules_uviewPlus_libs_config_props_link.Link,
-  ...uni_modules_uviewPlus_libs_config_props_list.List,
-  ...uni_modules_uviewPlus_libs_config_props_listItem.ListItem,
-  ...uni_modules_uviewPlus_libs_config_props_loadingIcon.LoadingIcon,
-  ...uni_modules_uviewPlus_libs_config_props_loadingPage.LoadingPage,
-  ...uni_modules_uviewPlus_libs_config_props_loadmore.Loadmore,
-  ...uni_modules_uviewPlus_libs_config_props_modal.Modal,
-  ...uni_modules_uviewPlus_libs_config_props_navbar.Navbar,
-  ...uni_modules_uviewPlus_libs_config_props_noNetwork.NoNetwork,
-  ...uni_modules_uviewPlus_libs_config_props_noticeBar.NoticeBar,
-  ...uni_modules_uviewPlus_libs_config_props_notify.Notify,
-  ...uni_modules_uviewPlus_libs_config_props_numberBox.NumberBox,
-  ...uni_modules_uviewPlus_libs_config_props_numberKeyboard.NumberKeyboard,
-  ...uni_modules_uviewPlus_libs_config_props_overlay.Overlay,
-  ...uni_modules_uviewPlus_libs_config_props_parse.Parse,
-  ...uni_modules_uviewPlus_libs_config_props_picker.Picker,
-  ...uni_modules_uviewPlus_libs_config_props_popup.Popup,
-  ...uni_modules_uviewPlus_libs_config_props_radio.Radio,
-  ...uni_modules_uviewPlus_libs_config_props_radioGroup.RadioGroup,
-  ...uni_modules_uviewPlus_libs_config_props_rate.Rate,
-  ...uni_modules_uviewPlus_libs_config_props_readMore.ReadMore,
-  ...uni_modules_uviewPlus_libs_config_props_row.Row,
-  ...uni_modules_uviewPlus_libs_config_props_rowNotice.RowNotice,
-  ...uni_modules_uviewPlus_libs_config_props_scrollList.ScrollList,
-  ...uni_modules_uviewPlus_libs_config_props_search.Search,
-  ...uni_modules_uviewPlus_libs_config_props_section.Section,
-  ...uni_modules_uviewPlus_libs_config_props_skeleton.Skeleton,
-  ...uni_modules_uviewPlus_libs_config_props_slider.Slider,
-  ...uni_modules_uviewPlus_libs_config_props_statusBar.StatusBar,
-  ...uni_modules_uviewPlus_libs_config_props_steps.Steps,
-  ...uni_modules_uviewPlus_libs_config_props_stepsItem.StepsItem,
-  ...uni_modules_uviewPlus_libs_config_props_sticky.Sticky,
-  ...uni_modules_uviewPlus_libs_config_props_subsection.Subsection,
-  ...uni_modules_uviewPlus_libs_config_props_swipeAction.SwipeAction,
-  ...uni_modules_uviewPlus_libs_config_props_swipeActionItem.SwipeActionItem,
-  ...uni_modules_uviewPlus_libs_config_props_swiper.Swiper,
-  ...uni_modules_uviewPlus_libs_config_props_swipterIndicator.SwipterIndicator,
-  ...uni_modules_uviewPlus_libs_config_props_switch.Switch,
-  ...uni_modules_uviewPlus_libs_config_props_tabbar.Tabbar,
-  ...uni_modules_uviewPlus_libs_config_props_tabbarItem.TabbarItem,
-  ...uni_modules_uviewPlus_libs_config_props_tabs.Tabs,
-  ...uni_modules_uviewPlus_libs_config_props_tag.Tag,
-  ...uni_modules_uviewPlus_libs_config_props_text.Text,
-  ...uni_modules_uviewPlus_libs_config_props_textarea.Textarea,
-  ...uni_modules_uviewPlus_libs_config_props_toast.Toast,
-  ...uni_modules_uviewPlus_libs_config_props_toolbar.Toolbar,
-  ...uni_modules_uviewPlus_libs_config_props_tooltip.Tooltip,
-  ...uni_modules_uviewPlus_libs_config_props_transition.Transition,
-  ...uni_modules_uviewPlus_libs_config_props_upload.Upload,
-  ...uni_modules_uviewPlus_libs_config_props_drawer.drawer
-};
-exports.props = props;

+ 0 - 18
unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props/actionSheet.js

@@ -1,18 +0,0 @@
-"use strict";
-const ActionSheet = {
-  // action-sheet组件
-  actionSheet: {
-    show: false,
-    title: "",
-    description: "",
-    actions: () => [],
-    index: "",
-    cancelText: "",
-    closeOnClickAction: true,
-    safeAreaInsetBottom: true,
-    openType: "",
-    closeOnClickOverlay: true,
-    round: 0
-  }
-};
-exports.ActionSheet = ActionSheet;

+ 0 - 18
unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props/album.js

@@ -1,18 +0,0 @@
-"use strict";
-const Album = {
-  // album 组件
-  album: {
-    urls: () => [],
-    keyName: "",
-    singleSize: 180,
-    multipleSize: 70,
-    space: 6,
-    singleMode: "scaleToFill",
-    multipleMode: "aspectFill",
-    maxCount: 9,
-    previewFullImage: true,
-    rowCount: 3,
-    showMore: true
-  }
-};
-exports.Album = Album;

+ 0 - 15
unpackage/dist/dev/mp-weixin/uni_modules/uview-plus/libs/config/props/alert.js

@@ -1,15 +0,0 @@
-"use strict";
-const Alert = {
-  // alert警告组件
-  alert: {
-    title: "",
-    type: "warning",
-    description: "",
-    closable: false,
-    showIcon: false,
-    effect: "light",
-    center: false,
-    fontSize: 14
-  }
-};
-exports.Alert = Alert;

この差分においてかなりの量のファイルが変更されているため、一部のファイルを表示していません