From 5fecc9e46d448df3de987504440c4fdd582f858e Mon Sep 17 00:00:00 2001
From: quanyawei <401863037@qq.com>
Date: Tue, 31 Oct 2023 10:35:40 +0800
Subject: [PATCH] fix:小程序秒级数据和登录授权

---
 uni_modules/uni-popup/components/uni-popup-dialog/keypress.js            |   45 
 uni_modules/uni-transition/package.json                                  |   84 +
 pages/actionChange/components/rectificationInfor.vue                     |    7 
 uni_modules/uni-popup/components/uni-popup/popup.js                      |   26 
 uni_modules/uni-popup/package.json                                       |   87 +
 uni_modules/uni-transition/readme.md                                     |   11 
 uni_modules/uni-popup/readme.md                                          |   17 
 uni_modules/ws-wx-privacy/readme.md                                      |  122 ++
 pages/actionChange/secondLevelData/index.vue                             |  596 ++++++++++
 uni_modules/uni-popup/changelog.md                                       |   68 +
 uni_modules/ws-wx-privacy/components/ws-wx-privacy/util.js               |   51 
 uni_modules/uni-popup/components/uni-popup-dialog/uni-popup-dialog.vue   |  275 ++++
 pages/actionChange/myInfor/index.vue                                     |    2 
 uni_modules/uni-popup/components/uni-popup/i18n/index.js                 |    8 
 .env.dev.js                                                              |    2 
 uni_modules/uni-popup/components/uni-popup/uni-popup.vue                 |  473 ++++++++
 uni_modules/uni-popup/components/uni-popup-share/uni-popup-share.vue     |  187 +++
 uni_modules/ws-wx-privacy/package.json                                   |   85 +
 pages/actionChange/agencyPage/index.vue                                  |    2 
 pages/login/login.vue                                                    |   18 
 pages/actionChange/newPage/index.vue                                     |    4 
 uni_modules/uni-transition/components/uni-transition/uni-transition.vue  |  286 +++++
 pages.json                                                               |    7 
 uni_modules/ws-wx-privacy/components/ws-wx-privacy/ws-wx-privacy.vue     |  287 +++++
 uni_modules/uni-popup/components/uni-popup-message/uni-popup-message.vue |  143 ++
 uni_modules/uni-popup/components/uni-popup/keypress.js                   |   45 
 uni_modules/uni-popup/components/uni-popup/i18n/zh-Hans.json             |    7 
 uni_modules/uni-transition/components/uni-transition/createAnimation.js  |  131 ++
 uni_modules/uni-transition/changelog.md                                  |   22 
 /dev/null                                                                |    0 
 pages/actionChange/secondLevelData/parameter.json                        |   44 
 uni_modules/uni-popup/components/uni-popup/i18n/en.json                  |    7 
 manifest.json                                                            |  148 +-
 uni_modules/ws-wx-privacy/changelog.md                                   |   22 
 utils/websoket.js                                                        |   91 +
 uni_modules/uni-popup/components/uni-popup/i18n/zh-Hant.json             |    7 
 36 files changed, 3,336 insertions(+), 81 deletions(-)

diff --git a/.env.dev.js b/.env.dev.js
index 8093bf2..fc8f4ea 100644
--- a/.env.dev.js
+++ b/.env.dev.js
@@ -1,6 +1,6 @@
 const config = {
 	// baseUrl: "http://120.26.43.34:8081/api/", //������
 	baseUrl: "https://qx.7drlb.com/api", //������
-	// baseUrl: "http://192.168.0.9:8081/api", //������
+	// baseUrl: "http://192.168.0.12:8081/api", //������
 };
 module.exports = config;
\ No newline at end of file
diff --git a/manifest.json b/manifest.json
index 5bf1825..e69eee1 100644
--- a/manifest.json
+++ b/manifest.json
@@ -1,75 +1,75 @@
 {
-    "name" : "test",
-    "appid" : "__UNI__93C3197",
-    "description" : "",
-    "versionName" : "1.0.0",
-    "versionCode" : "100",
-    "transformPx" : false,
-    /* 5+App������������ */
-    "app-plus" : {
-        "usingComponents" : true,
-        "nvueStyleCompiler" : "uni-app",
-        "compilerVersion" : 3,
-        "splashscreen" : {
-            "alwaysShowBeforeRender" : true,
-            "waiting" : true,
-            "autoclose" : true,
-            "delay" : 0
-        },
-        /* ������������ */
-        "modules" : {},
-        /* ������������������ */
-        "distribute" : {
-            /* android������������ */
-            "android" : {
-                "permissions" : [
-                    "<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\"/>",
-                    "<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>",
-                    "<uses-permission android:name=\"android.permission.VIBRATE\"/>",
-                    "<uses-permission android:name=\"android.permission.READ_LOGS\"/>",
-                    "<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>",
-                    "<uses-feature android:name=\"android.hardware.camera.autofocus\"/>",
-                    "<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>",
-                    "<uses-permission android:name=\"android.permission.CAMERA\"/>",
-                    "<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>",
-                    "<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>",
-                    "<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>",
-                    "<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>",
-                    "<uses-permission android:name=\"android.permission.FLASHLIGHT\"/>",
-                    "<uses-feature android:name=\"android.hardware.camera\"/>",
-                    "<uses-permission android:name=\"android.permission.WRITE_SETTINGS\"/>"
-                ]
-            },
-            /* ios������������ */
-            "ios" : {},
-            /* SDK������ */
-            "sdkConfigs" : {}
-        }
-    },
-    /* ��������������������� */
-    "quickapp" : {},
-    /* ��������������������� */
-    "mp-weixin" : {
-        "appid" : "wx41f4c3c007545088",
-        "setting" : {
-            "urlCheck" : false,
-            "es6" : true,
-            "postcss" : true,
-            "minified" : true
-        },
-        "usingComponents" : true
-    },
-    "mp-alipay" : {
-        "usingComponents" : true
-    },
-    "mp-baidu" : {
-        "usingComponents" : true
-    },
-    "mp-toutiao" : {
-        "usingComponents" : true
-    },
-    "uniStatistics" : {
-        "enable" : false
-    },
-    "vueVersion" : "2"
-}
+	"name": "test",
+	"appid": "__UNI__93C3197",
+	"description": "",
+	"versionName": "1.0.0",
+	"versionCode": "100",
+	"transformPx": false,
+	/* 5+App������������ */
+	"app-plus": {
+		"usingComponents": true,
+		"nvueStyleCompiler": "uni-app",
+		"compilerVersion": 3,
+		"splashscreen": {
+			"alwaysShowBeforeRender": true,
+			"waiting": true,
+			"autoclose": true,
+			"delay": 0
+		},
+		/* ������������ */
+		"modules": {},
+		/* ������������������ */
+		"distribute": {
+			/* android������������ */
+			"android": {
+				"permissions": ["<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\"/>",
+					"<uses-permission android:name=\"android.permission.MOUNT_UNMOUNT_FILESYSTEMS\"/>",
+					"<uses-permission android:name=\"android.permission.VIBRATE\"/>",
+					"<uses-permission android:name=\"android.permission.READ_LOGS\"/>",
+					"<uses-permission android:name=\"android.permission.ACCESS_WIFI_STATE\"/>",
+					"<uses-feature android:name=\"android.hardware.camera.autofocus\"/>",
+					"<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\"/>",
+					"<uses-permission android:name=\"android.permission.CAMERA\"/>",
+					"<uses-permission android:name=\"android.permission.GET_ACCOUNTS\"/>",
+					"<uses-permission android:name=\"android.permission.READ_PHONE_STATE\"/>",
+					"<uses-permission android:name=\"android.permission.CHANGE_WIFI_STATE\"/>",
+					"<uses-permission android:name=\"android.permission.WAKE_LOCK\"/>",
+					"<uses-permission android:name=\"android.permission.FLASHLIGHT\"/>",
+					"<uses-feature android:name=\"android.hardware.camera\"/>",
+					"<uses-permission android:name=\"android.permission.WRITE_SETTINGS\"/>"
+				]
+			},
+			/* ios������������ */
+			"ios": {},
+			/* SDK������ */
+			"sdkConfigs": {}
+		}
+	},
+	/* ��������������������� */
+	"quickapp": {},
+	/* ��������������������� */
+	"mp-weixin": {
+		"appid": "wxf95fb77e0b1f8c09",
+		"__usePrivacyCheck__": true,
+		"setting": {
+			"urlCheck": false,
+			"es6": true,
+			"postcss": true,
+			"minified": true
+		},
+		"usingComponents": true
+	},
+	"mp-alipay": {
+		"usingComponents": true
+	},
+	"mp-baidu": {
+		"usingComponents": true
+	},
+	"mp-toutiao": {
+		"usingComponents": true
+	},
+	"uniStatistics": {
+		"enable": false
+	},
+	"vueVersion": "2"
+}
\ No newline at end of file
diff --git a/pages.json b/pages.json
index 0122ed8..395274f 100644
--- a/pages.json
+++ b/pages.json
@@ -44,6 +44,13 @@
 				"disableSwipeBack": true,
 				"navigationStyle": "custom"
 			}
+		}, {
+			"path": "pages/actionChange/secondLevelData/index",
+			"style": {
+				"navigationBarTitleText": "������������",
+				"enablePullDownRefresh": false,
+				"disableSwipeBack": true
+			}
 		}
 	]
 	// "tabBar": {
diff --git a/pages/actionChange/agencyPage/index.vue b/pages/actionChange/agencyPage/index.vue
index 563f912..68b842e 100644
--- a/pages/actionChange/agencyPage/index.vue
+++ b/pages/actionChange/agencyPage/index.vue
@@ -349,7 +349,7 @@
 					id: e.allocationId
 				}).then(res => {
 					let data = res.data
-					data.pageState = data.state === 50 || data.state === 40 ? 'view' : pageState
+					data.pageState = e.stateName === '���������' ? pageState : 'view'
 					let myData = JSON.stringify(data)
 					uni.navigateTo({
 						url: '/pages/actionChange/workOrderDetails/index?infor=' + myData,
diff --git a/pages/actionChange/components/rectificationInfor.vue b/pages/actionChange/components/rectificationInfor.vue
index fad999f..61e5a2f 100644
--- a/pages/actionChange/components/rectificationInfor.vue
+++ b/pages/actionChange/components/rectificationInfor.vue
@@ -145,8 +145,11 @@
 					let name = item.fileType === 1 ? 'name.png' : 'name.mp4'
 					this.fileList.push(`${this.baseUrl}/file/preview/${item.fileId}?${name}`) // ������
 				})
-				console.log('this.fileList', this.basicInfor.fileBaseList)
-				console.log('this.fileList', this.fileList)
+			}
+			let userInfor = JSON.parse(uni.getStorageSync('userInfor') || '{}')
+			console.log('userInfor', userInfor)
+			if (this.basicInfor.pageState === 'edit') {
+				this.form.changeName = userInfor.userName
 			}
 		},
 		methods: {
diff --git a/pages/actionChange/myInfor/index.vue b/pages/actionChange/myInfor/index.vue
index a186dec..f0169ba 100644
--- a/pages/actionChange/myInfor/index.vue
+++ b/pages/actionChange/myInfor/index.vue
@@ -11,6 +11,8 @@
 				<u-cell icon="account-fill" title="������" :value="userInfor.account"></u-cell>
 				<u-cell icon="integral-fill" title="������������" :value="unitName"></u-cell>
 				<u-cell icon="phone-fill" title="���������" :value="userInfor.mobile"></u-cell>
+				<u-cell icon="clock-fill" title="������������������" v-if="userInfor.device===1" isLink
+					url="/pages/actionChange/secondLevelData/index"></u-cell>
 			</u-cell-group>
 		</view>
 		<view class="bunts">
diff --git a/pages/actionChange/newPage/index.vue b/pages/actionChange/newPage/index.vue
index e84ee88..894ac12 100644
--- a/pages/actionChange/newPage/index.vue
+++ b/pages/actionChange/newPage/index.vue
@@ -265,8 +265,8 @@
 					this.form.escalationUnitId = data
 					this.sumbitForm.escalationUnitId = userInfor.unitId
 				}
-				this.form.escalationName = userInfor.name || ''
-				this.sumbitForm.escalationName = userInfor.name || ''
+				this.form.escalationName = userInfor.userName || ''
+				this.sumbitForm.escalationName = userInfor.userName || ''
 				this.form.investigationType = 1
 				this.sumbitForm.investigationType = 1
 				console.log('this.sumbitForm', this.sumbitForm)
diff --git a/pages/actionChange/secondLevelData/index.vue b/pages/actionChange/secondLevelData/index.vue
new file mode 100644
index 0000000..e6b8a30
--- /dev/null
+++ b/pages/actionChange/secondLevelData/index.vue
@@ -0,0 +1,596 @@
+<template>
+	<view class="rootBg">
+		<view class="">
+			<view class="ridoa">
+				<u-radio-group v-model="value" placement="row" :size='radioOption.size'
+					:labelColor='radioOption.labelColor' :labelSize='radioOption.labelSize' @change='changeSearchType'>
+					<u-radio activeColor="#19be6b" label="������������������" name="0" :labelSize='radioOption.labelSize'
+						:labelColor='radioOption.labelColor'></u-radio>
+					<u-radio activeColor="#19be6b" label="������������������" name="1" :labelSize='radioOption.labelSize'
+						:labelColor='radioOption.labelColor'></u-radio>
+				</u-radio-group>
+			</view>
+			<view class="" v-if="value==='1'">
+				<u-input placeholder="���������Mac���" :placeholderStyle='placeholderStyle' color="#fff" v-model='macName'>
+					<template slot="suffix">
+						<u-button @tap="searchMacList" text="������" type="success" size="small"></u-button>
+					</template>
+				</u-input>
+			</view>
+			<view class="" v-else>
+				<u-form ref="uForm" label-width="80" :model="form">
+					<u-form-item border-bottom @click="showeEscalationTime = true ;hideKeyboard('orgName','orgId')">
+						<u-input v-model="form.orgName" disabled disabled-color="#ffffff" placeholder="���������������"
+							type="select" />
+					</u-form-item>
+					<u-form-item border-bottom @click="selectSite">
+						<u-input v-model="form.siteName" disabled disabled-color="#ffffff" placeholder="���������������"
+							type="select" />
+					</u-form-item>
+				</u-form>
+				<u-picker :show="showeEscalationTime" :columns="columns" @confirm="selectBack" keyName="name"
+					@cancel="showeEscalationTime = false"></u-picker>
+			</view>
+		</view>
+		<view v-if="wsData2">
+			<u-cell title="���������" :value="windDirData"></u-cell>
+		</view>
+		<view class="boxPadd">
+			<u-list v-if="showData.length>0">
+				<u-list-item v-for="(item, index) in showData" :key="index">
+					<u-row customStyle="margin-bottom: 10px">
+						<u-col span="3">
+							<view>{{ item.sensorCode | sensorFilter}}</view>
+						</u-col>
+						<u-col span="6" textAlign="right">
+							<u-line-progress :percentage="item.alarm" :activeColor="item.colour"></u-line-progress>
+						</u-col>
+						<u-col span="3" textAlign="right">
+							<view>{{ item.value || ''}} </view>
+						</u-col>
+					</u-row>
+				</u-list-item>
+			</u-list>
+		</view>
+		<u-toast ref="uToast"></u-toast>
+		<u-modal :show="showModel" title='���������Mac���' showCancelButton @cancel='showModel=false' @confirm='selectMac'>
+			<view class="slot-content">
+				<u-radio-group v-model="modeleMacSelect" iconPlacement="right" placement='column' borderBottom='true'>
+					<view v-for="(item,index) in macList" :key="index" class="ridioBox">
+						<u-radio activeColor="#19be6b" :label="item.mac" :name="item.mac"></u-radio>
+					</view>
+				</u-radio-group>
+			</view>
+		</u-modal>
+	</view>
+</template>
+<script>
+	import json from '@/pages/actionChange/secondLevelData/parameter.json'
+	import wsRequest from '@/utils/websoket.js'
+	export default {
+		data() {
+			return {
+				modeleMacSelect: '',
+				value: '0',
+				showModel: false,
+				showeEscalationTime: false,
+				columns: [],
+				form: {
+					orgName: '',
+					orgId: '',
+					siteName: '',
+					siteId: ''
+				},
+				selectForm: {
+					name: '',
+					id: ''
+				},
+				macList: [],
+				radioOption: {
+					size: '20px',
+					labelColor: '#fff',
+					labelSize: '18px'
+				},
+				placeholderStyle: 'color: #fff',
+				macName: '',
+				defaultMonitorItems: [],
+				chartSensorKey: [],
+				coreMonitorItems: [],
+				fixedMonitorItems: [],
+				totalArray: [],
+				alarmLevel: null,
+				aqi: 0,
+				baseUrl: '',
+				windDir: 'null',
+				windDeg: 180,
+				wsData2: null,
+				// ���������������
+				alarmProgress: {},
+				// ������������
+				alarmColour: {},
+				// ������������������
+				alarmBg: {},
+				timer: '',
+				isLoading: true
+			}
+		},
+		filters: {
+			// ���������������websocket���������������key���
+			sensorFilter: function(value) {
+				if (!value) return ''
+				return json[value]
+			}
+		},
+		computed: {
+			windDirData() {
+				if (this.wsData2) {
+					console.log('this.windDir', this.windDir)
+					return `${this.windDir} (${this.wsData2.a01008})`
+				} else {
+					return ''
+				}
+			},
+			showData() {
+				return [...this.defaultMonitorItems, ...this.coreMonitorItems]
+			}
+		},
+		created() {
+			this.getOrgs()
+		},
+		onUnload() {
+			let that = this
+			this.socketTask.close()
+			that.isLoading = false
+			that.timer = ''
+		},
+		methods: {
+			getData() {
+				this.queryAlarmByMac()
+				this.getHourlyAqi()
+				this.sensorLayout()
+			},
+			changeSearchType() {
+				this.macName = ''
+			},
+			selectMac() {
+				this.macName = this.modeleMacSelect
+				this.showModel = false
+				if (this.socketTask) {
+					this.socketTask.onClose()
+				}
+				this.getData()
+			},
+			searchMacList() {
+				this.$http.httpGet('/AppDevice/fuzzySearch', {
+					mac: this.macName
+				}).then(res => {
+					this.showModel = true
+					if (res.data && res.data.length > 10) {
+						this.macList = res.data.slice(0, 10)
+					}
+				}).catch(res => {
+					uni.$u.toast(res)
+				})
+			},
+			selectSite() {
+				if (this.form.orgId === '') {
+					uni.showToast({
+						title: '���������������������',
+						icon: 'none',
+					})
+				} else {
+					this.selectForm = {
+							name: 'siteName',
+							id: 'siteId'
+						},
+						this.getSites()
+				}
+			},
+			hideKeyboard(name, id) {
+				this.selectForm = {
+					'name': name,
+					'id': id
+				}
+				this.getOrgs()
+			},
+			selectBack(e) {
+				if (this.selectForm.name === 'orgName') {
+					this.form = {
+						orgName: '',
+						orgId: '',
+						siteName: '',
+						siteId: ''
+					}
+				} else {
+					this.macName = e.value[0].mac
+					if (this.socketTask) {
+						this.socketTask.onClose()
+					}
+					this.getData()
+				}
+				this.form[this.selectForm.name] = e.value[0].name
+				this.form[this.selectForm.id] = e.value[0].id
+				this.showeEscalationTime = false
+			},
+			getOrgs() {
+				this.$http.httpGet('/AppDevice/selectOrganization').then(res => {
+					this.columns = []
+					this.columns.push(res.data)
+				}).catch(res => {
+					uni.$u.toast(res)
+				})
+			},
+			getSites() {
+				let params = {
+					organizationId: this.form.orgId
+				}
+				this.$http.httpGet('/AppDevice/selectDevice', params).then(res => {
+					console.log(res)
+					this.columns = []
+					this.columns.push(res.data)
+					this.showeEscalationTime = true
+				}).catch(res => {
+					uni.$u.toast(res)
+					console.log(res)
+				})
+			},
+			sensorLayout() {
+				let params = {
+					mac: this.macName
+				}
+				this.$http.httpGet('/organizationLayout/getLayoutByMac', params).then(res => {
+					this.chartSensorKey = res.data.chartSensorKey
+					this.coreMonitorItems = res.data.coreMonitorItems
+					this.defaultMonitorItems = res.data.defaultMonitorItems
+					this.fixedMonitorItems = res.data.fixedMonitorItems
+					this.totalArray.push(...this.coreMonitorItems, ...this.defaultMonitorItems, ...this
+						.fixedMonitorItems)
+					this.getSensorMonthAvg()
+					this.connectSocket()
+				}).catch(res => {
+					uni.$u.toast(res)
+					console.log(res)
+				})
+			},
+			// ���������������������������������������
+			getSensorMonthAvg() {
+				let params = {
+					sensorCode: this.chartSensorKey[0].sensorCode,
+					mac: this.macName
+				}
+				this.$http.httpGet('/deviceInfo/getMonthAvg', params).then(res => {
+					this.average = res.data.avg
+				}).catch(res => {
+					uni.$u.toast(res)
+					console.log(res)
+				})
+			},
+			// ���������������������
+			queryAlarmByMac() {
+				let params = {
+					mac: this.macName
+				}
+				this.$http.httpGet('/deviceInfo/queryAlarmByMac', params).then(res => {
+					this.alarmLevel = res.data.alarmLevel
+				}).catch(res => {
+					uni.$u.toast(res)
+					console.log(res)
+				})
+			},
+			// ������������������������������
+			getHourlyAqi() {
+				let params = {
+					mac: this.macName
+				}
+				this.$http.httpGet('/deviceInfo/getHourlyAqi', params).then(res => {
+					this.aqi = res.data.AQI
+				}).catch(res => {
+					uni.$u.toast(res)
+					console.log(res)
+				})
+			},
+			handlerMsg(msg) {
+				this.wsData2 = JSON.parse(msg.data)
+				if (this.wsData2.dustld) {
+					this.wsData2.dustld = this.wsData2.dustld.replace(/g/, 'ug')
+				}
+				// ������������
+				if (this.wsData2.a01008) {
+					var windDirs = Number(this.wsData2.a01008.substr(0, this.wsData2.a01008.length - 1))
+					this.windDeg = windDirs
+					if (windDirs === 0) {
+						this.windDir = '������'
+					} else if (windDirs > 0 && windDirs < 90) {
+						this.windDir = '���������'
+					} else if (windDirs === 90) {
+						this.windDir = '������'
+					} else if (windDirs > 90 && windDirs < 180) {
+						this.windDir = '���������'
+					} else if (windDirs === 180) {
+						this.windDir = '������'
+					} else if (windDirs > 180 && windDirs < 270) {
+						this.windDir = '���������'
+					} else if (windDirs === 270) {
+						this.windDir = '������'
+					} else if (windDirs > 270 && windDirs < 360) {
+						this.windDir = '���������'
+					}
+				}
+				this.alarmColour = {}
+				this.alarmProgress = {}
+				this.alarmBg = {}
+				// ������������
+				for (const key in this.wsData2) {
+					if (this.chartSensorKey && key === this.chartSensorKey[0].sensorCode) {
+						this.chartSensorKey[0].value = this.wsData2[key]
+					}
+					for (const keys in this.alarmLevel) {
+						// ���������������������
+						if (key === keys && JSON.parse(this.alarmLevel[keys])) {
+							if (parseFloat(this.wsData2[key]) >= parseFloat(JSON.parse(this.alarmLevel[keys])[5])) {
+								this.alarmColour[keys] = '#000000'
+								this.alarmBg[keys] = 5
+							} else if (parseFloat(this.wsData2[key]) >= parseFloat(JSON.parse(this.alarmLevel[keys])[4])) {
+								this.alarmColour[keys] = '#c00261'
+								this.alarmBg[keys] = 4
+							} else if (parseFloat(this.wsData2[key]) >= parseFloat(JSON.parse(this.alarmLevel[keys])[3])) {
+								this.alarmColour[keys] = '#fc0101'
+								this.alarmBg[keys] = 3
+							} else if (parseFloat(this.wsData2[key]) >= parseFloat(JSON.parse(this.alarmLevel[keys])[2])) {
+								this.alarmColour[keys] = '#ff8202'
+								this.alarmBg[keys] = 2
+							} else if (parseFloat(this.wsData2[key]) >= parseFloat(JSON.parse(this.alarmLevel[keys])[1])) {
+								this.alarmColour[keys] = '#fdff00'
+								this.alarmBg[keys] = 1
+							} else {
+								this.alarmColour[keys] = '#00ff01'
+								this.alarmBg[keys] = 0
+							}
+						} else if (key === keys) {
+							this.alarmColour[keys] = '#00ff01'
+							this.alarmBg[keys] = 0
+						}
+						// ������������������������
+						if (key === keys && JSON.parse(this.alarmLevel[keys])) {
+							if (JSON.parse(this.alarmLevel[keys])[5]) {
+								const percentage = Math.round(
+									(parseFloat(this.wsData2[key]) / parseFloat(JSON.parse(this.alarmLevel[keys])[
+									5])) * 100)
+								this.alarmProgress[keys] = percentage
+							} else if (JSON.parse(this.alarmLevel[keys])[4]) {
+								const percentage = Math.round(
+									(parseFloat(this.wsData2[key]) / parseFloat(JSON.parse(this.alarmLevel[keys])[
+									4])) * 100)
+								this.alarmProgress[keys] = percentage
+							} else if (JSON.parse(this.alarmLevel[keys])[3]) {
+								const percentage = Math.round(
+									(parseFloat(this.wsData2[key]) / parseFloat(JSON.parse(this.alarmLevel[keys])[
+									3])) * 100)
+								this.alarmProgress[keys] = percentage
+							} else if (JSON.parse(this.alarmLevel[keys])[2]) {
+								const percentage = Math.round(
+									(parseFloat(this.wsData2[key]) / parseFloat(JSON.parse(this.alarmLevel[keys])[
+									2])) * 100)
+								this.alarmProgress[keys] = percentage
+							} else if (JSON.parse(this.alarmLevel[keys])[1]) {
+								const percentage = Math.round(
+									(parseFloat(this.wsData2[key]) / parseFloat(JSON.parse(this.alarmLevel[keys])[
+									1])) * 100)
+								this.alarmProgress[keys] = percentage
+							} else if (JSON.parse(this.alarmLevel[keys])[0]) {
+								const percentage = Math.round(
+									(parseFloat(this.wsData2[key]) / parseFloat(JSON.parse(this.alarmLevel[keys])[
+									0])) * 100)
+								this.alarmProgress[keys] = percentage
+							}
+						} else if (key === keys) {
+							this.alarmProgress[keys] = 0
+						}
+						if (this.alarmProgress[keys] > 100) {
+							this.alarmProgress[keys] = 100
+						}
+					}
+				}
+				// ������������������������������������
+				for (let i = 0; i < this.totalArray.length; i++) {
+					for (const key in this.wsData2) {
+						if (key !== 'time') {
+							// ���������������������
+							var tempDecimal = this.wsData2[key].replace(/[^\d.]/g, '').split('.')[1]
+							if (this.totalArray[i].sensorCode === key) {
+								// ���������������������������
+								if (this.totalArray[i].sensorCode === 'a19002') {
+									this.totalArray[i].value = parseInt(this.wsData2[key])
+								} else if (this.totalArray[i].sensorCode === 'a01002') {
+									this.totalArray[i].value = parseInt(this.wsData2[key]) + '%'
+									// ������TVOCQ������������������������������������������������
+								} else if (this.totalArray[i].sensorCode !== 'a99054' && Number(tempDecimal) === 0) {
+									this.totalArray[i].value = parseInt(this.wsData2[key]) + this.wsData2[key].split(' ')[
+										1]
+								} else {
+									this.totalArray[i].value = this.wsData2[key]
+								}
+							}
+						}
+					}
+					for (const key in this.alarmProgress) {
+						if (this.totalArray[i].sensorCode === key) {
+							this.totalArray[i].alarm = this.alarmProgress[key]
+						}
+					}
+					console.log('this.totalArray', this.totalArray)
+					console.log('this.alarmColour', this.alarmColour)
+					for (const key in this.alarmColour) {
+						if (this.totalArray[i].sensorCode === key) {
+							this.totalArray[i].colour = this.alarmColour[key]
+						}
+					}
+					for (const key in this.alarmBg) {
+						if (this.totalArray[i].sensorCode === key) {
+							this.totalArray[i].bg = this.alarmBg[key]
+						}
+					}
+				}
+			},
+			//������websocket
+			connectSocket() {
+				if (!this.isLoading) {
+					this.socketTask.close()
+					this.socketTask = null
+				}
+				this.baseUrl = this.$storage.get('baseUrl')
+				let that = this
+				let socketUrl = this.baseUrl + '/singleDevice/' + this.macName
+				socketUrl = socketUrl.replace('https', 'wss').replace('http', 'ws')
+				console.log('������������websocket')
+				this.socketTask = uni.connectSocket({
+					url: socketUrl,
+					success(res) {
+						console.log('websocket������������')
+						that.isLoading = true
+					},
+					fail(err) {
+						console.log('������', err)
+					}
+				}, )
+				this.socketTask.onOpen(function(res) {
+					console.log('WebSocket������������������')
+					that.isLoading = true
+					// that.getStatus()
+					// that.heart()
+				})
+				this.socketTask.onMessage(function(res) {
+					console.log('������������������������' + res.data)
+					that.handlerMsg(res) //������������������������������������������
+				})
+				this.socketTask.onError(function(res) {
+					console.log('WebSocket���������������������������������')
+					console.log(res)
+					// this.isSuccess = false
+					// that.connectSocket()
+					//������������������
+					that.reconnect()
+				})
+				// // ������������������ -
+				this.socketTask.onClose(e => {
+					console.log('WebSocket���������������')
+					clearInterval(that.timer)
+					that.timer = ''
+					if (!that.isClose) {
+						that.reconnect()
+					}
+				})
+				console.log(this.socketTask)
+			},
+			//������������������
+			reconnect() {
+				console.log('������������������')
+				this.socketTask.close()
+				this.socketTask = null
+				if (this.isLoading) {
+					this.connectSocket()
+				}
+			},
+			//������������
+			sendSocketMessage(msg) {
+				console.log('������������')
+				console.log(msg)
+				return new Promise((reslove, reject) => {
+					this.socketTask.send({
+						data: msg,
+						success(res) {
+							console.log('������������')
+							reslove(res)
+						},
+						fail(res) {
+							console.log('������������')
+							console.log(res)
+							reject(res)
+						}
+					})
+				})
+			},
+			//������
+			heart() {
+				let that = this
+				clearInterval(this.timer)
+				this.timer = ''
+				let msg = {
+					'type': 'heartbeat',
+				}
+				this.timer = setInterval(() => {
+					that.sendSocketMessage(JSON.stringify(msg)).then(res => {
+						console.log('������������')
+					}).catch(res => {
+						console.log('������������')
+						console.log((res))
+					})
+				}, 2000)
+			},
+			beforeDestroy() {
+				if (this.socketTask) {
+					this.socketTask.close()
+					this.socketTask = null
+				}
+				if (this.timer) {
+					clearInterval(this.timer) // ���Vue������������������������������������������
+				}
+			},
+		}
+	}
+</script>
+<style scoped lang="scss">
+	.rootBg {
+		min-height: 100%;
+		color: #fff;
+		/* ��������������������������������� */
+		background-position: center center;
+		/* ������������������ */
+		background-repeat: no-repeat;
+		/* ���������������������������������������������������������������������viewport������ */
+		background-attachment: fixed;
+		/* ������������������������������������ */
+		background-size: cover;
+		background-image: url('');
+	}
+
+	.boxPadd {
+		padding: 5px 10px;
+	}
+
+	/deep/.u-line-progress__text {
+		color: #000 !important;
+	}
+
+	/deep/.u-radio-group--row {
+		justify-content: center;
+	}
+
+	.ridoa {
+		text-align: center;
+		padding: 10px 0px;
+	}
+
+	/deep/.placeholderColor {
+		color: #fff;
+	}
+
+	/deep/.u-form {
+		display: flex;
+		justify-content: space-evenly;
+	}
+
+	.slot-content {
+		width: 80%;
+	}
+
+	/deep/.u-cell__body,
+	/deep/.u-cell__title-text,
+	/deep/.u-cell__value {
+		color: #fff !important;
+	}
+
+	.ridioBox {
+		margin-bottom: 10px;
+	}
+</style>
\ No newline at end of file
diff --git a/pages/actionChange/secondLevelData/parameter.json b/pages/actionChange/secondLevelData/parameter.json
new file mode 100644
index 0000000..ddf93f4
--- /dev/null
+++ b/pages/actionChange/secondLevelData/parameter.json
@@ -0,0 +1,44 @@
+{
+	"flylon": "������",
+	"a00e12": "������������",
+	"a00e34": "TSP",
+	"a00e13": "������",
+	"a21005": "������������",
+	"a21004": "������������",
+	"a21026": "������������",
+	"a21028": "���������",
+	"flyhig": "������",
+	"a21001": "������",
+	"a40002": "���������",
+	"a21022": "������",
+	"a00e19": "������������",
+	"a40001": "������������",
+	"a01001": "������",
+	"a25005": "���������",
+	"a05024": "������",
+	"a21024": "���������",
+	"a40003": "������������",
+	"a25003": "������",
+	"a01002": "������",
+	"a25002": "���",
+	"a23001": "������",
+	"a01007": "������",
+	"a01006": "������",
+	"a01008": "������",
+	"a30001": "������",
+	"a19002": "������������",
+	"a19001": "������",
+	"a34002": "PM10",
+	"a34004": "PM2.5",
+	"dustld": "���������",
+	"PORRST": "������������",
+	"a00e03": "���������0.3",
+	"a00e04": "���������2.5",
+	"a06001": "������",
+	"a99054": "TVOC",
+	"a35e21": "���������",
+	"a01011": "������������",
+	"a24088": "���������������",
+	"flylat": "������",
+	"a31001": "������"
+}
\ No newline at end of file
diff --git a/pages/login/login.vue b/pages/login/login.vue
index 04a8c27..97bcf15 100644
--- a/pages/login/login.vue
+++ b/pages/login/login.vue
@@ -29,6 +29,7 @@
 				<u-button @click="submit">������</u-button>
 			</view>
 		</view>
+		<ws-wx-privacy id="privacy-popup" enableAutoProtocol></ws-wx-privacy>
 	</view>
 </template>
 <script>
@@ -44,6 +45,7 @@
 	export default {
 		data() {
 			return {
+				titlePrivacy: '������������������������',
 				labelStyle: {
 					color: '#fff'
 				},
@@ -81,9 +83,23 @@
 			uni.hideHomeButton()
 		},
 		methods: {
+			doRequire() {
+				uni.requirePrivacyAuthorize({
+					success: () => {
+						console.log('������')
+						// ������������������
+						// ���������������������
+						this.getlogin()
+					},
+					fail: () => {
+						console.log('������')
+					}, // ������������������
+					complete: () => {}
+				})
+			},
 			submit() {
 				this.$refs.uForm.validate().then(res => {
-					this.getlogin()
+					this.doRequire()
 				}).catch(errors => {})
 			},
 			//������
diff --git a/static/img/headSculpture.png b/static/img/headSculpture.png
deleted file mode 100644
index 479675f..0000000
--- a/static/img/headSculpture.png
+++ /dev/null
Binary files differ
diff --git a/static/img/shouye.png b/static/img/shouye.png
deleted file mode 100644
index 6cc733a..0000000
--- a/static/img/shouye.png
+++ /dev/null
Binary files differ
diff --git a/static/img/shouyeClick.png b/static/img/shouyeClick.png
deleted file mode 100644
index f0effdd..0000000
--- a/static/img/shouyeClick.png
+++ /dev/null
Binary files differ
diff --git a/static/img/wode-.png b/static/img/wode-.png
deleted file mode 100644
index bcc3f2f..0000000
--- a/static/img/wode-.png
+++ /dev/null
Binary files differ
diff --git a/static/img/wodeClick.png b/static/img/wodeClick.png
deleted file mode 100644
index 6687d89..0000000
--- a/static/img/wodeClick.png
+++ /dev/null
Binary files differ
diff --git a/static/img/xinjian.png b/static/img/xinjian.png
deleted file mode 100644
index 0449374..0000000
--- a/static/img/xinjian.png
+++ /dev/null
Binary files differ
diff --git a/static/img/xinjianClick.png b/static/img/xinjianClick.png
deleted file mode 100644
index 69439e8..0000000
--- a/static/img/xinjianClick.png
+++ /dev/null
Binary files differ
diff --git a/uni_modules/uni-popup/changelog.md b/uni_modules/uni-popup/changelog.md
new file mode 100644
index 0000000..bc59f07
--- /dev/null
+++ b/uni_modules/uni-popup/changelog.md
@@ -0,0 +1,68 @@
+## 1.8.3���2023-04-17���
+- ������ uni-popup ������������������ bug
+## 1.8.2���2023-02-02���
+- uni-popup-dialog ������������ inputType ������
+## 1.8.1���2022-12-01���
+- ������ nvue ��� v-show ������
+## 1.8.0���2022-11-29���
+- ������ ������������
+## 1.7.9���2022-04-02���
+- ������ ������������������������������bug
+## 1.7.8���2022-03-28���
+- ������ ���������������������������bug
+## 1.7.7���2022-03-17���
+- ������ ������������open���������������Bug
+## 1.7.6���2022-02-14���
+- ������ safeArea ���������������������false���bug
+## 1.7.5���2022-01-19���
+- ������ isMaskClick ���������bug
+## 1.7.4���2022-01-19���
+- ������ cancelText \ confirmText ������ ���������������������
+- ������ maskBackgroundColor ������ ���������������������������
+- ������ maskClick������ ��������� isMaskClick ���������������������������������������
+## 1.7.3���2022-01-13���
+- ������ ������ safeArea ������������������bug
+## 1.7.2���2021-11-26���
+- ������ ������������
+## 1.7.1���2021-11-26���
+- ������ vuedoc ������������
+## 1.7.0���2021-11-19���
+- ������ ������UI���������������������������������:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource)
+- ���������������������:[https://uniapp.dcloud.io/component/uniui/uni-popup](https://uniapp.dcloud.io/component/uniui/uni-popup)
+## 1.6.2���2021-08-24���
+- ������ ���������������
+## 1.6.1���2021-07-30���
+- ������ vue3������������������������
+## 1.6.0���2021-07-13���
+- ������������ vue3���������������vue3��������������� [uni-app ������������ vue3 ������](https://ask.dcloud.net.cn/article/37834)
+## 1.5.0���2021-06-23���
+- ������ mask-click ���������������������
+## 1.4.5���2021-06-22���
+- ������ nvue ���������������������������������������������������������������������Bug
+## 1.4.4���2021-06-18���
+- ������ H5���������������������������������������������������������������������Bug
+## 1.4.3���2021-06-08���
+- ������ ��������� watch ������
+- ������ safeArea ������������������������
+- ������ ���������������������������������������������Bug
+## 1.4.2���2021-05-12���
+- ������ ������������������
+## 1.4.1���2021-04-29���
+- ������ ��������������� input ���textarea ������������������������������
+## 1.4.0 ���2021-04-29���
+- ������ type ��������� left\right ������������������������
+- ������ open(String:type) ������������ ��������������� type ������ ���������������������������������������
+- ������ backgroundColor ������������������������������������,������������������������
+- ������ safeArea ������������������������������������
+- ������ App\h5\���������������������������������������������Bug
+- ������ App ������������������Bug
+- ������ ���������������������������������������������������
+- ������ ���������������������������������
+## 1.2.9���2021-02-05���
+- ������ ���������������������������uni_modules������������
+## 1.2.8���2021-02-05���
+- ���������uni_modules������������
+## 1.2.7���2021-02-05���
+- ���������uni_modules������������
+- ������ ������ PC ���
+- ������ uni-popup-message ���uni-popup-dialog������������������ PC ���
diff --git a/uni_modules/uni-popup/components/uni-popup-dialog/keypress.js b/uni_modules/uni-popup/components/uni-popup-dialog/keypress.js
new file mode 100644
index 0000000..6ef26a2
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup-dialog/keypress.js
@@ -0,0 +1,45 @@
+// #ifdef H5
+export default {
+  name: 'Keypress',
+  props: {
+    disable: {
+      type: Boolean,
+      default: false
+    }
+  },
+  mounted () {
+    const keyNames = {
+      esc: ['Esc', 'Escape'],
+      tab: 'Tab',
+      enter: 'Enter',
+      space: [' ', 'Spacebar'],
+      up: ['Up', 'ArrowUp'],
+      left: ['Left', 'ArrowLeft'],
+      right: ['Right', 'ArrowRight'],
+      down: ['Down', 'ArrowDown'],
+      delete: ['Backspace', 'Delete', 'Del']
+    }
+    const listener = ($event) => {
+      if (this.disable) {
+        return
+      }
+      const keyName = Object.keys(keyNames).find(key => {
+        const keyName = $event.key
+        const value = keyNames[key]
+        return value === keyName || (Array.isArray(value) && value.includes(keyName))
+      })
+      if (keyName) {
+        // ���������������������������������
+        setTimeout(() => {
+          this.$emit(keyName, {})
+        }, 0)
+      }
+    }
+    document.addEventListener('keyup', listener)
+    this.$once('hook:beforeDestroy', () => {
+      document.removeEventListener('keyup', listener)
+    })
+  },
+	render: () => {}
+}
+// #endif
diff --git a/uni_modules/uni-popup/components/uni-popup-dialog/uni-popup-dialog.vue b/uni_modules/uni-popup/components/uni-popup-dialog/uni-popup-dialog.vue
new file mode 100644
index 0000000..b5eee79
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup-dialog/uni-popup-dialog.vue
@@ -0,0 +1,275 @@
+<template>
+	<view class="uni-popup-dialog">
+		<view class="uni-dialog-title">
+			<text class="uni-dialog-title-text" :class="['uni-popup__'+dialogType]">{{titleText}}</text>
+		</view>
+		<view v-if="mode === 'base'" class="uni-dialog-content">
+			<slot>
+				<text class="uni-dialog-content-text">{{content}}</text>
+			</slot>
+		</view>
+		<view v-else class="uni-dialog-content">
+			<slot>
+				<input class="uni-dialog-input" v-model="val" :type="inputType" :placeholder="placeholderText" :focus="focus" >
+			</slot>
+		</view>
+		<view class="uni-dialog-button-group">
+			<view class="uni-dialog-button" @click="closeDialog">
+				<text class="uni-dialog-button-text">{{closeText}}</text>
+			</view>
+			<view class="uni-dialog-button uni-border-left" @click="onOk">
+				<text class="uni-dialog-button-text uni-button-color">{{okText}}</text>
+			</view>
+		</view>
+
+	</view>
+</template>
+
+<script>
+	import popup from '../uni-popup/popup.js'
+	import {
+	initVueI18n
+	} from '@dcloudio/uni-i18n'
+	import messages from '../uni-popup/i18n/index.js'
+	const {	t } = initVueI18n(messages)
+	/**
+	 * PopUp ���������-���������������
+	 * @description ���������-���������������
+	 * @tutorial https://ext.dcloud.net.cn/plugin?id=329
+	 * @property {String} value input ���������������������
+	 * @property {String} placeholder input ���������������������
+	 * @property {String} type = [success|warning|info|error] ������������
+	 *  @value success ������
+	 * 	@value warning ������
+	 * 	@value info ������
+	 * 	@value error ������
+	 * @property {String} mode = [base|input] ���������
+	 * 	@value base ���������������
+	 * 	@value input ������������������
+	 * @property {String} content ���������������
+	 * @property {Boolean} beforeClose ������������������������
+	 * @event {Function} confirm ������������������������
+	 * @event {Function} close ������������������������
+	 */
+
+	export default {
+		name: "uniPopupDialog",
+		mixins: [popup],
+		emits:['confirm','close'],
+		props: {
+			inputType:{
+				type: String,
+				default: 'text'
+			},
+			value: {
+				type: [String, Number],
+				default: ''
+			},
+			placeholder: {
+				type: [String, Number],
+				default: ''
+			},
+			type: {
+				type: String,
+				default: 'error'
+			},
+			mode: {
+				type: String,
+				default: 'base'
+			},
+			title: {
+				type: String,
+				default: ''
+			},
+			content: {
+				type: String,
+				default: ''
+			},
+			beforeClose: {
+				type: Boolean,
+				default: false
+			},
+			cancelText:{
+				type: String,
+				default: ''
+			},
+			confirmText:{
+				type: String,
+				default: ''
+			}
+		},
+		data() {
+			return {
+				dialogType: 'error',
+				focus: false,
+				val: ""
+			}
+		},
+		computed: {
+			okText() {
+				return this.confirmText || t("uni-popup.ok")
+			},
+			closeText() {
+				return this.cancelText || t("uni-popup.cancel")
+			},
+			placeholderText() {
+				return this.placeholder || t("uni-popup.placeholder")
+			},
+			titleText() {
+				return this.title || t("uni-popup.title")
+			}
+		},
+		watch: {
+			type(val) {
+				this.dialogType = val
+			},
+			mode(val) {
+				if (val === 'input') {
+					this.dialogType = 'info'
+				}
+			},
+			value(val) {
+				this.val = val
+			}
+		},
+		created() {
+			// ���������������������������
+			this.popup.disableMask()
+			// this.popup.closeMask()
+			if (this.mode === 'input') {
+				this.dialogType = 'info'
+				this.val = this.value
+			} else {
+				this.dialogType = this.type
+			}
+		},
+		mounted() {
+			this.focus = true
+		},
+		methods: {
+			/**
+			 * ������������������
+			 */
+			onOk() {
+				if (this.mode === 'input'){
+					this.$emit('confirm', this.val)
+				}else{
+					this.$emit('confirm')
+				}
+				if(this.beforeClose) return
+				this.popup.close()
+			},
+			/**
+			 * ������������������
+			 */
+			closeDialog() {
+				this.$emit('close')
+				if(this.beforeClose) return
+				this.popup.close()
+			},
+			close(){
+				this.popup.close()
+			}
+		}
+	}
+</script>
+
+<style lang="scss" >
+	.uni-popup-dialog {
+		width: 300px;
+		border-radius: 11px;
+		background-color: #fff;
+	}
+
+	.uni-dialog-title {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		justify-content: center;
+		padding-top: 25px;
+	}
+
+	.uni-dialog-title-text {
+		font-size: 16px;
+		font-weight: 500;
+	}
+
+	.uni-dialog-content {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		justify-content: center;
+		align-items: center;
+		padding: 20px;
+	}
+
+	.uni-dialog-content-text {
+		font-size: 14px;
+		color: #6C6C6C;
+	}
+
+	.uni-dialog-button-group {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		border-top-color: #f5f5f5;
+		border-top-style: solid;
+		border-top-width: 1px;
+	}
+
+	.uni-dialog-button {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+
+		flex: 1;
+		flex-direction: row;
+		justify-content: center;
+		align-items: center;
+		height: 45px;
+	}
+
+	.uni-border-left {
+		border-left-color: #f0f0f0;
+		border-left-style: solid;
+		border-left-width: 1px;
+	}
+
+	.uni-dialog-button-text {
+		font-size: 16px;
+		color: #333;
+	}
+
+	.uni-button-color {
+		color: #007aff;
+	}
+
+	.uni-dialog-input {
+		flex: 1;
+		font-size: 14px;
+		border: 1px #eee solid;
+		height: 40px;
+		padding: 0 10px;
+		border-radius: 5px;
+		color: #555;
+	}
+
+	.uni-popup__success {
+		color: #4cd964;
+	}
+
+	.uni-popup__warn {
+		color: #f0ad4e;
+	}
+
+	.uni-popup__error {
+		color: #dd524d;
+	}
+
+	.uni-popup__info {
+		color: #909399;
+	}
+</style>
diff --git a/uni_modules/uni-popup/components/uni-popup-message/uni-popup-message.vue b/uni_modules/uni-popup/components/uni-popup-message/uni-popup-message.vue
new file mode 100644
index 0000000..91370a8
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup-message/uni-popup-message.vue
@@ -0,0 +1,143 @@
+<template>
+	<view class="uni-popup-message">
+		<view class="uni-popup-message__box fixforpc-width" :class="'uni-popup__'+type">
+			<slot>
+				<text class="uni-popup-message-text" :class="'uni-popup__'+type+'-text'">{{message}}</text>
+			</slot>
+		</view>
+	</view>
+</template>
+
+<script>
+	import popup from '../uni-popup/popup.js'
+	/**
+	 * PopUp ���������-������������
+	 * @description ���������-������������
+	 * @tutorial https://ext.dcloud.net.cn/plugin?id=329
+	 * @property {String} type = [success|warning|info|error] ������������
+	 *  @value success ������
+	 * 	@value warning ������
+	 * 	@value info ������
+	 * 	@value error ������
+	 * @property {String} message ������������������
+	 * @property {String} duration ������������������������ 0 ���������������������
+	 */
+
+	export default {
+		name: 'uniPopupMessage',
+		mixins:[popup],
+		props: {
+			/**
+			 * ������ success/warning/info/error	  ������ success
+			 */
+			type: {
+				type: String,
+				default: 'success'
+			},
+			/**
+			 * ������������
+			 */
+			message: {
+				type: String,
+				default: ''
+			},
+			/**
+			 * ������������������������ 0 ���������������������
+			 */
+			duration: {
+				type: Number,
+				default: 3000
+			},
+			maskShow:{
+				type:Boolean,
+				default:false
+			}
+		},
+		data() {
+			return {}
+		},
+		created() {
+			this.popup.maskShow = this.maskShow
+			this.popup.messageChild = this
+		},
+		methods: {
+			timerClose(){
+				if(this.duration === 0) return
+				clearTimeout(this.timer) 
+				this.timer = setTimeout(()=>{
+					this.popup.close()
+				},this.duration)
+			}
+		}
+	}
+</script>
+<style lang="scss" >
+	.uni-popup-message {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		justify-content: center;
+	}
+
+	.uni-popup-message__box {
+		background-color: #e1f3d8;
+		padding: 10px 15px;
+		border-color: #eee;
+		border-style: solid;
+		border-width: 1px;
+		flex: 1;
+	}
+
+	@media screen and (min-width: 500px) {
+		.fixforpc-width {
+			margin-top: 20px;
+			border-radius: 4px;
+			flex: none;
+			min-width: 380px;
+			/* #ifndef APP-NVUE */
+			max-width: 50%;
+			/* #endif */
+			/* #ifdef APP-NVUE */
+			max-width: 500px;
+			/* #endif */
+		}
+	}
+
+	.uni-popup-message-text {
+		font-size: 14px;
+		padding: 0;
+	}
+
+	.uni-popup__success {
+		background-color: #e1f3d8;
+	}
+
+	.uni-popup__success-text {
+		color: #67C23A;
+	}
+
+	.uni-popup__warn {
+		background-color: #faecd8;
+	}
+
+	.uni-popup__warn-text {
+		color: #E6A23C;
+	}
+
+	.uni-popup__error {
+		background-color: #fde2e2;
+	}
+
+	.uni-popup__error-text {
+		color: #F56C6C;
+	}
+
+	.uni-popup__info {
+		background-color: #F2F6FC;
+	}
+
+	.uni-popup__info-text {
+		color: #909399;
+	}
+</style>
diff --git a/uni_modules/uni-popup/components/uni-popup-share/uni-popup-share.vue b/uni_modules/uni-popup/components/uni-popup-share/uni-popup-share.vue
new file mode 100644
index 0000000..5be7624
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup-share/uni-popup-share.vue
@@ -0,0 +1,187 @@
+<template>
+	<view class="uni-popup-share">
+		<view class="uni-share-title"><text class="uni-share-title-text">{{shareTitleText}}</text></view>
+		<view class="uni-share-content">
+			<view class="uni-share-content-box">
+				<view class="uni-share-content-item" v-for="(item,index) in bottomData" :key="index" @click.stop="select(item,index)">
+					<image class="uni-share-image" :src="item.icon" mode="aspectFill"></image>
+					<text class="uni-share-text">{{item.text}}</text>
+				</view>
+
+			</view>
+		</view>
+		<view class="uni-share-button-box">
+			<button class="uni-share-button" @click="close">{{cancelText}}</button>
+		</view>
+	</view>
+</template>
+
+<script>
+	import popup from '../uni-popup/popup.js'
+	import {
+	initVueI18n
+	} from '@dcloudio/uni-i18n'
+	import messages from '../uni-popup/i18n/index.js'
+	const {	t	} = initVueI18n(messages)
+	export default {
+		name: 'UniPopupShare',
+		mixins:[popup],
+		emits:['select'],
+		props: {
+			title: {
+				type: String,
+				default: ''
+			},
+			beforeClose: {
+				type: Boolean,
+				default: false
+			}
+		},
+		data() {
+			return {
+				bottomData: [{
+						text: '������',
+						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/c2b17470-50be-11eb-b680-7980c8a877b8.png',
+						name: 'wx'
+					},
+					{
+						text: '���������',
+						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/d684ae40-50be-11eb-8ff1-d5dcf8779628.png',
+						name: 'wx'
+					},
+					{
+						text: 'QQ',
+						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/e7a79520-50be-11eb-b997-9918a5dda011.png',
+						name: 'qq'
+					},
+					{
+						text: '������',
+						icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/0dacdbe0-50bf-11eb-8ff1-d5dcf8779628.png',
+						name: 'sina'
+					},
+					// {
+					// 	text: '������',
+					// 	icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/1ec6e920-50bf-11eb-8a36-ebb87efcf8c0.png',
+					// 	name: 'copy'
+					// },
+					// {
+					// 	text: '������',
+					// 	icon: 'https://vkceyugu.cdn.bspapp.com/VKCEYUGU-dc-site/2e0fdfe0-50bf-11eb-b997-9918a5dda011.png',
+					// 	name: 'more'
+					// }
+				]
+			}
+		},
+		created() {},
+		computed: {
+			cancelText() {
+				return t("uni-popup.cancel")
+			},
+		shareTitleText() {
+				return this.title || t("uni-popup.shareTitle")
+			}
+		},
+		methods: {
+			/**
+			 * ������������
+			 */
+			select(item, index) {
+				this.$emit('select', {
+					item,
+					index
+				})
+				this.close()
+
+			},
+			/**
+			 * ������������
+			 */
+			close() {
+				if(this.beforeClose) return
+				this.popup.close()
+			}
+		}
+	}
+</script>
+<style lang="scss" >
+	.uni-popup-share {
+		background-color: #fff;
+		border-top-left-radius: 11px;
+		border-top-right-radius: 11px;
+	}
+	.uni-share-title {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		align-items: center;
+		justify-content: center;
+		height: 40px;
+	}
+	.uni-share-title-text {
+		font-size: 14px;
+		color: #666;
+	}
+	.uni-share-content {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		justify-content: center;
+		padding-top: 10px;
+	}
+
+	.uni-share-content-box {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		flex-wrap: wrap;
+		width: 360px;
+	}
+
+	.uni-share-content-item {
+		width: 90px;
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: column;
+		justify-content: center;
+		padding: 10px 0;
+		align-items: center;
+	}
+
+	.uni-share-content-item:active {
+		background-color: #f5f5f5;
+	}
+
+	.uni-share-image {
+		width: 30px;
+		height: 30px;
+	}
+
+	.uni-share-text {
+		margin-top: 10px;
+		font-size: 14px;
+		color: #3B4144;
+	}
+
+	.uni-share-button-box {
+		/* #ifndef APP-NVUE */
+		display: flex;
+		/* #endif */
+		flex-direction: row;
+		padding: 10px 15px;
+	}
+
+	.uni-share-button {
+		flex: 1;
+		border-radius: 50px;
+		color: #666;
+		font-size: 16px;
+	}
+
+	.uni-share-button::after {
+		border-radius: 50px;
+	}
+</style>
diff --git a/uni_modules/uni-popup/components/uni-popup/i18n/en.json b/uni_modules/uni-popup/components/uni-popup/i18n/en.json
new file mode 100644
index 0000000..7f1bd06
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup/i18n/en.json
@@ -0,0 +1,7 @@
+{
+	"uni-popup.cancel": "cancel",
+	"uni-popup.ok": "ok",
+	"uni-popup.placeholder": "pleace enter",
+	"uni-popup.title": "Hint",
+	"uni-popup.shareTitle": "Share to"
+}
diff --git a/uni_modules/uni-popup/components/uni-popup/i18n/index.js b/uni_modules/uni-popup/components/uni-popup/i18n/index.js
new file mode 100644
index 0000000..de7509c
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup/i18n/index.js
@@ -0,0 +1,8 @@
+import en from './en.json'
+import zhHans from './zh-Hans.json'
+import zhHant from './zh-Hant.json'
+export default {
+	en,
+	'zh-Hans': zhHans,
+	'zh-Hant': zhHant
+}
diff --git a/uni_modules/uni-popup/components/uni-popup/i18n/zh-Hans.json b/uni_modules/uni-popup/components/uni-popup/i18n/zh-Hans.json
new file mode 100644
index 0000000..5e3003c
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup/i18n/zh-Hans.json
@@ -0,0 +1,7 @@
+{
+	"uni-popup.cancel": "������",
+	"uni-popup.ok": "������",
+	"uni-popup.placeholder": "���������",
+		"uni-popup.title": "������",
+		"uni-popup.shareTitle": "���������"
+}
diff --git a/uni_modules/uni-popup/components/uni-popup/i18n/zh-Hant.json b/uni_modules/uni-popup/components/uni-popup/i18n/zh-Hant.json
new file mode 100644
index 0000000..13e39eb
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup/i18n/zh-Hant.json
@@ -0,0 +1,7 @@
+{
+	"uni-popup.cancel": "������",
+	"uni-popup.ok": "������",
+	"uni-popup.placeholder": "���������",
+	"uni-popup.title": "������",
+	"uni-popup.shareTitle": "���������"
+}
diff --git a/uni_modules/uni-popup/components/uni-popup/keypress.js b/uni_modules/uni-popup/components/uni-popup/keypress.js
new file mode 100644
index 0000000..62dda46
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup/keypress.js
@@ -0,0 +1,45 @@
+// #ifdef H5
+export default {
+  name: 'Keypress',
+  props: {
+    disable: {
+      type: Boolean,
+      default: false
+    }
+  },
+  mounted () {
+    const keyNames = {
+      esc: ['Esc', 'Escape'],
+      tab: 'Tab',
+      enter: 'Enter',
+      space: [' ', 'Spacebar'],
+      up: ['Up', 'ArrowUp'],
+      left: ['Left', 'ArrowLeft'],
+      right: ['Right', 'ArrowRight'],
+      down: ['Down', 'ArrowDown'],
+      delete: ['Backspace', 'Delete', 'Del']
+    }
+    const listener = ($event) => {
+      if (this.disable) {
+        return
+      }
+      const keyName = Object.keys(keyNames).find(key => {
+        const keyName = $event.key
+        const value = keyNames[key]
+        return value === keyName || (Array.isArray(value) && value.includes(keyName))
+      })
+      if (keyName) {
+        // ���������������������������������
+        setTimeout(() => {
+          this.$emit(keyName, {})
+        }, 0)
+      }
+    }
+    document.addEventListener('keyup', listener)
+    // this.$once('hook:beforeDestroy', () => {
+    //   document.removeEventListener('keyup', listener)
+    // })
+  },
+	render: () => {}
+}
+// #endif
diff --git a/uni_modules/uni-popup/components/uni-popup/popup.js b/uni_modules/uni-popup/components/uni-popup/popup.js
new file mode 100644
index 0000000..c4e5781
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup/popup.js
@@ -0,0 +1,26 @@
+
+export default {
+	data() {
+		return {
+			
+		}
+	},
+	created(){
+		this.popup = this.getParent()
+	},
+	methods:{
+		/**
+		 * ���������������������
+		 */
+		getParent(name = 'uniPopup') {
+			let parent = this.$parent;
+			let parentName = parent.$options.name;
+			while (parentName !== name) {
+				parent = parent.$parent;
+				if (!parent) return false
+				parentName = parent.$options.name;
+			}
+			return parent;
+		},
+	}
+}
diff --git a/uni_modules/uni-popup/components/uni-popup/uni-popup.vue b/uni_modules/uni-popup/components/uni-popup/uni-popup.vue
new file mode 100644
index 0000000..54afee2
--- /dev/null
+++ b/uni_modules/uni-popup/components/uni-popup/uni-popup.vue
@@ -0,0 +1,473 @@
+<template>
+	<view v-if="showPopup" class="uni-popup" :class="[popupstyle, isDesktop ? 'fixforpc-z-index' : '']">
+		<view @touchstart="touchstart">
+			<uni-transition key="1" v-if="maskShow" name="mask" mode-class="fade" :styles="maskClass"
+				:duration="duration" :show="showTrans" @click="onTap" />
+			<uni-transition key="2" :mode-class="ani" name="content" :styles="transClass" :duration="duration"
+				:show="showTrans" @click="onTap">
+				<view class="uni-popup__wrapper" :style="{ backgroundColor: bg }" :class="[popupstyle]" @click="clear">
+					<slot />
+				</view>
+			</uni-transition>
+		</view>
+		<!-- #ifdef H5 -->
+		<keypress v-if="maskShow" @esc="onTap" />
+		<!-- #endif -->
+	</view>
+</template>
+
+<script>
+	// #ifdef H5
+	import keypress from './keypress.js'
+	// #endif
+
+	/**
+	 * PopUp ���������
+	 * @description ���������������������������������������������������
+	 * @tutorial https://ext.dcloud.net.cn/plugin?id=329
+	 * @property {String} type = [top|center|bottom|left|right|message|dialog|share] ������������
+	 * 	@value top ������������
+	 * 	@value center ������������
+	 * 	@value bottom ������������
+	 * 	@value left		������������
+	 * 	@value right  ������������
+	 * 	@value message ������������
+	 * 	@value dialog ���������
+	 * 	@value share ������������������
+	 * @property {Boolean} animation = [true|false] ������������������
+	 * @property {Boolean} maskClick = [true|false] ������������������������������(������)
+	 * @property {Boolean} isMaskClick = [true|false] ������������������������������
+	 * @property {String}  backgroundColor ������������������
+	 * @property {String}  maskBackgroundColor ������������
+	 * @property {Boolean} safeArea		   ���������������������������
+	 * @event {Function} change ���������������������������e={show: false}
+	 * @event {Function} maskClick ������������������
+	 */
+
+	export default {
+		name: 'uniPopup',
+		components: {
+			// #ifdef H5
+			keypress
+			// #endif
+		},
+		emits: ['change', 'maskClick'],
+		props: {
+			// ������������
+			animation: {
+				type: Boolean,
+				default: true
+			},
+			// ������������������������������top: ������������������bottom���������������������center������������������
+			// message: ������������ ; dialog : ���������
+			type: {
+				type: String,
+				default: 'center'
+			},
+			// maskClick
+			isMaskClick: {
+				type: Boolean,
+				default: null
+			},
+			// TODO 2 ������������������������ ��������� isMaskClick
+			maskClick: {
+				type: Boolean,
+				default: null
+			},
+			backgroundColor: {
+				type: String,
+				default: 'none'
+			},
+			safeArea: {
+				type: Boolean,
+				default: true
+			},
+			maskBackgroundColor: {
+				type: String,
+				default: 'rgba(0, 0, 0, 0.4)'
+			},
+		},
+
+		watch: {
+			/**
+			 * ������type������
+			 */
+			type: {
+				handler: function(type) {
+					if (!this.config[type]) return
+					this[this.config[type]](true)
+				},
+				immediate: true
+			},
+			isDesktop: {
+				handler: function(newVal) {
+					if (!this.config[newVal]) return
+					this[this.config[this.type]](true)
+				},
+				immediate: true
+			},
+			/**
+			 * ���������������������������
+			 * @param {Object} val
+			 */
+			maskClick: {
+				handler: function(val) {
+					this.mkclick = val
+				},
+				immediate: true
+			},
+			isMaskClick: {
+				handler: function(val) {
+					this.mkclick = val
+				},
+				immediate: true
+			},
+			// H5 ���������������������
+			showPopup(show) {
+				// #ifdef H5
+				// fix by mehaotian ������ h5 ���������������������
+				document.getElementsByTagName('body')[0].style.overflow = show ? 'hidden' : 'visible'
+				// #endif
+			}
+		},
+		data() {
+			return {
+				duration: 300,
+				ani: [],
+				showPopup: false,
+				showTrans: false,
+				popupWidth: 0,
+				popupHeight: 0,
+				config: {
+					top: 'top',
+					bottom: 'bottom',
+					center: 'center',
+					left: 'left',
+					right: 'right',
+					message: 'top',
+					dialog: 'center',
+					share: 'bottom'
+				},
+				maskClass: {
+					position: 'fixed',
+					bottom: 0,
+					top: 0,
+					left: 0,
+					right: 0,
+					backgroundColor: 'rgba(0, 0, 0, 0.4)'
+				},
+				transClass: {
+					position: 'fixed',
+					left: 0,
+					right: 0
+				},
+				maskShow: true,
+				mkclick: true,
+				popupstyle: this.isDesktop ? 'fixforpc-top' : 'top'
+			}
+		},
+		computed: {
+			isDesktop() {
+				return this.popupWidth >= 500 && this.popupHeight >= 500
+			},
+			bg() {
+				if (this.backgroundColor === '' || this.backgroundColor === 'none') {
+					return 'transparent'
+				}
+				return this.backgroundColor
+			}
+		},
+		mounted() {
+			const fixSize = () => {
+				const {
+					windowWidth,
+					windowHeight,
+					windowTop,
+					safeArea,
+					screenHeight,
+					safeAreaInsets
+				} = uni.getSystemInfoSync()
+				this.popupWidth = windowWidth
+				this.popupHeight = windowHeight + (windowTop || 0)
+				// TODO fix by mehaotian ��������������������������� ,������������ios ������ app ios ������������������������������������
+				if (safeArea && this.safeArea) {
+					// #ifdef MP-WEIXIN
+					this.safeAreaInsets = screenHeight - safeArea.bottom
+					// #endif
+					// #ifndef MP-WEIXIN
+					this.safeAreaInsets = safeAreaInsets.bottom
+					// #endif
+				} else {
+					this.safeAreaInsets = 0
+				}
+			}
+			fixSize()
+			// #ifdef H5
+			// window.addEventListener('resize', fixSize)
+			// this.$once('hook:beforeDestroy', () => {
+			// 	window.removeEventListener('resize', fixSize)
+			// })
+			// #endif
+		},
+		// #ifndef VUE3
+		// TODO vue2
+		destroyed() {
+			this.setH5Visible()
+		},
+		// #endif
+		// #ifdef VUE3
+		// TODO vue3
+		unmounted() {
+			this.setH5Visible()
+		},
+		// #endif
+		created() {
+			// this.mkclick =  this.isMaskClick || this.maskClick
+			if (this.isMaskClick === null && this.maskClick === null) {
+				this.mkclick = true
+			} else {
+				this.mkclick = this.isMaskClick !== null ? this.isMaskClick : this.maskClick
+			}
+			if (this.animation) {
+				this.duration = 300
+			} else {
+				this.duration = 0
+			}
+			// TODO ������ message ���������������������������������
+			this.messageChild = null
+			// TODO ���������������������������
+			this.clearPropagation = false
+			this.maskClass.backgroundColor = this.maskBackgroundColor
+		},
+		methods: {
+			setH5Visible() {
+				// #ifdef H5
+				// fix by mehaotian ������ h5 ���������������������
+				document.getElementsByTagName('body')[0].style.overflow = 'visible'
+				// #endif
+			},
+			/**
+			 * ���������������������������������
+			 */
+			closeMask() {
+				this.maskShow = false
+			},
+			/**
+			 * ������������������������������������
+			 */
+			disableMask() {
+				this.mkclick = false
+			},
+			// TODO nvue ������������
+			clear(e) {
+				// #ifndef APP-NVUE
+				e.stopPropagation()
+				// #endif
+				this.clearPropagation = true
+			},
+
+			open(direction) {
+				// fix by mehaotian ���������������������������������
+				if (this.showPopup) {
+					return
+				}
+				let innerType = ['top', 'center', 'bottom', 'left', 'right', 'message', 'dialog', 'share']
+				if (!(direction && innerType.indexOf(direction) !== -1)) {
+					direction = this.type
+				}
+				if (!this.config[direction]) {
+					console.error('���������������', direction)
+					return
+				}
+				this[this.config[direction]]()
+				this.$emit('change', {
+					show: true,
+					type: direction
+				})
+			},
+			close(type) {
+				this.showTrans = false
+				this.$emit('change', {
+					show: false,
+					type: this.type
+				})
+				clearTimeout(this.timer)
+				// // ���������������������
+				// this.customOpen && this.customClose()
+				this.timer = setTimeout(() => {
+					this.showPopup = false
+				}, 300)
+			},
+			// TODO ��������������������������������������������������� ������������������
+			touchstart() {
+				this.clearPropagation = false
+			},
+
+			onTap() {
+				if (this.clearPropagation) {
+					// fix by mehaotian ������ nvue
+					this.clearPropagation = false
+					return
+				}
+				this.$emit('maskClick')
+				if (!this.mkclick) return
+				this.close()
+			},
+			/**
+			 * ������������������������
+			 */
+			top(type) {
+				this.popupstyle = this.isDesktop ? 'fixforpc-top' : 'top'
+				this.ani = ['slide-top']
+				this.transClass = {
+					position: 'fixed',
+					left: 0,
+					right: 0,
+					backgroundColor: this.bg
+				}
+				// TODO ������ type ������ ������������������
+				if (type) return
+				this.showPopup = true
+				this.showTrans = true
+				this.$nextTick(() => {
+					if (this.messageChild && this.type === 'message') {
+						this.messageChild.timerClose()
+					}
+				})
+			},
+			/**
+			 * ������������������������
+			 */
+			bottom(type) {
+				this.popupstyle = 'bottom'
+				this.ani = ['slide-bottom']
+				this.transClass = {
+					position: 'fixed',
+					left: 0,
+					right: 0,
+					bottom: 0,
+					paddingBottom: this.safeAreaInsets + 'px',
+					backgroundColor: this.bg
+				}
+				// TODO ������ type ������ ������������������
+				if (type) return
+				this.showPopup = true
+				this.showTrans = true
+			},
+			/**
+			 * ������������������������
+			 */
+			center(type) {
+				this.popupstyle = 'center'
+				this.ani = ['zoom-out', 'fade']
+				this.transClass = {
+					position: 'fixed',
+					/* #ifndef APP-NVUE */
+					display: 'flex',
+					flexDirection: 'column',
+					/* #endif */
+					bottom: 0,
+					left: 0,
+					right: 0,
+					top: 0,
+					justifyContent: 'center',
+					alignItems: 'center'
+				}
+				// TODO ������ type ������ ������������������
+				if (type) return
+				this.showPopup = true
+				this.showTrans = true
+			},
+			left(type) {
+				this.popupstyle = 'left'
+				this.ani = ['slide-left']
+				this.transClass = {
+					position: 'fixed',
+					left: 0,
+					bottom: 0,
+					top: 0,
+					backgroundColor: this.bg,
+					/* #ifndef APP-NVUE */
+					display: 'flex',
+					flexDirection: 'column'
+					/* #endif */
+				}
+				// TODO ������ type ������ ������������������
+				if (type) return
+				this.showPopup = true
+				this.showTrans = true
+			},
+			right(type) {
+				this.popupstyle = 'right'
+				this.ani = ['slide-right']
+				this.transClass = {
+					position: 'fixed',
+					bottom: 0,
+					right: 0,
+					top: 0,
+					backgroundColor: this.bg,
+					/* #ifndef APP-NVUE */
+					display: 'flex',
+					flexDirection: 'column'
+					/* #endif */
+				}
+				// TODO ������ type ������ ������������������
+				if (type) return
+				this.showPopup = true
+				this.showTrans = true
+			}
+		}
+	}
+</script>
+<style lang="scss">
+	.uni-popup {
+		position: fixed;
+		/* #ifndef APP-NVUE */
+		z-index: 99;
+
+		/* #endif */
+		&.top,
+		&.left,
+		&.right {
+			/* #ifdef H5 */
+			top: var(--window-top);
+			/* #endif */
+			/* #ifndef H5 */
+			top: 0;
+			/* #endif */
+		}
+
+		.uni-popup__wrapper {
+			/* #ifndef APP-NVUE */
+			display: block;
+			/* #endif */
+			position: relative;
+
+			/* iphonex ������������������������������������������ */
+			/* #ifndef APP-NVUE */
+			// padding-bottom: constant(safe-area-inset-bottom);
+			// padding-bottom: env(safe-area-inset-bottom);
+			/* #endif */
+			&.left,
+			&.right {
+				/* #ifdef H5 */
+				padding-top: var(--window-top);
+				/* #endif */
+				/* #ifndef H5 */
+				padding-top: 0;
+				/* #endif */
+				flex: 1;
+			}
+		}
+	}
+
+	.fixforpc-z-index {
+		/* #ifndef APP-NVUE */
+		z-index: 999;
+		/* #endif */
+	}
+
+	.fixforpc-top {
+		top: 0;
+	}
+</style>
diff --git a/uni_modules/uni-popup/package.json b/uni_modules/uni-popup/package.json
new file mode 100644
index 0000000..f40556b
--- /dev/null
+++ b/uni_modules/uni-popup/package.json
@@ -0,0 +1,87 @@
+{
+	"id": "uni-popup",
+	"displayName": "uni-popup ���������",
+	"version": "1.8.3",
+	"description": " Popup ������������������������������",
+	"keywords": [
+        "uni-ui",
+        "���������",
+        "������",
+        "popup",
+        "������"
+    ],
+	"repository": "https://github.com/dcloudio/uni-ui",
+	"engines": {
+		"HBuilderX": ""
+	},
+	"directories": {
+		"example": "../../temps/example_temps"
+	},
+    "dcloudext": {
+        "sale": {
+			"regular": {
+				"price": "0.00"
+			},
+			"sourcecode": {
+				"price": "0.00"
+			}
+		},
+		"contact": {
+			"qq": ""
+		},
+		"declaration": {
+			"ads": "���",
+			"data": "���",
+			"permissions": "���"
+		},
+        "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui",
+        "type": "component-vue"
+	},
+	"uni_modules": {
+		"dependencies": [
+			"uni-scss",
+			"uni-transition"
+		],
+		"encrypt": [],
+		"platforms": {
+			"cloud": {
+				"tcb": "y",
+				"aliyun": "y"
+			},
+			"client": {
+				"App": {
+					"app-vue": "y",
+					"app-nvue": "y"
+				},
+				"H5-mobile": {
+					"Safari": "y",
+					"Android Browser": "y",
+					"���������������(Android)": "y",
+					"QQ���������(Android)": "y"
+				},
+				"H5-pc": {
+					"Chrome": "y",
+					"IE": "y",
+					"Edge": "y",
+					"Firefox": "y",
+					"Safari": "y"
+				},
+				"���������": {
+					"������": "y",
+					"������": "y",
+					"������": "y",
+					"������������": "y",
+					"QQ": "y"
+				},
+				"���������": {
+					"������": "u",
+					"������": "u"
+                },
+                "Vue": {
+                    "vue2": "y",
+                    "vue3": "y"
+                }
+			}
+		}
+	}
+}
diff --git a/uni_modules/uni-popup/readme.md b/uni_modules/uni-popup/readme.md
new file mode 100644
index 0000000..fdad4b3
--- /dev/null
+++ b/uni_modules/uni-popup/readme.md
@@ -0,0 +1,17 @@
+
+
+## Popup ���������
+> **������������uni-popup**
+> ������������ `uPopup`
+> ���������������`uni-transition`
+
+
+���������������������������������������������������������������������������
+
+### [������������](https://uniapp.dcloud.io/component/uniui/uni-popup)
+#### ������������������������������������������������uni-ui������������������������������������ uni-ui ������������871950839 
+
+
+
+
+
diff --git a/uni_modules/uni-transition/changelog.md b/uni_modules/uni-transition/changelog.md
new file mode 100644
index 0000000..70c1cd4
--- /dev/null
+++ b/uni_modules/uni-transition/changelog.md
@@ -0,0 +1,22 @@
+## 1.3.2���2023-05-04���
+- ������ NVUE ���������������������
+## 1.3.1���2021-11-23���
+- ������ init ���������������������
+## 1.3.0���2021-11-19���
+- ������ ������UI���������������������������������:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource)
+- ���������������������:[https://uniapp.dcloud.io/component/uniui/uni-transition](https://uniapp.dcloud.io/component/uniui/uni-transition)
+## 1.2.1���2021-09-27���
+- ������ init ������������������ Bug
+## 1.2.0���2021-07-30���
+- ������������ vue3��������������� vue3 ��������������� [uni-app ������������ vue3 ������](https://ask.dcloud.net.cn/article/37834)
+## 1.1.1���2021-05-12���
+- ������ ������������
+- ������ ��������������������������� Bug
+## 1.1.0���2021-04-22���
+- ������ ���������������������������
+- ������ custom-class ��� NVUE ��������������������� class ������������
+- ������ ���������������������������������������
+- ������ ���������������������������
+- ������ ������������
+## 1.0.2���2021-02-05���
+- ��������� uni_modules ������������
diff --git a/uni_modules/uni-transition/components/uni-transition/createAnimation.js b/uni_modules/uni-transition/components/uni-transition/createAnimation.js
new file mode 100644
index 0000000..8f89b18
--- /dev/null
+++ b/uni_modules/uni-transition/components/uni-transition/createAnimation.js
@@ -0,0 +1,131 @@
+// const defaultOption = {
+// 	duration: 300,
+// 	timingFunction: 'linear',
+// 	delay: 0,
+// 	transformOrigin: '50% 50% 0'
+// }
+// #ifdef APP-NVUE
+const nvueAnimation = uni.requireNativePlugin('animation')
+// #endif
+class MPAnimation {
+	constructor(options, _this) {
+		this.options = options
+		// ���iOS10+QQ���������������������������������������������������������������������������Proxy���������������������parameter should be Object instead of ProxyObject���������
+		this.animation = uni.createAnimation({
+			...options
+		})
+		this.currentStepAnimates = {}
+		this.next = 0
+		this.$ = _this
+
+	}
+
+	_nvuePushAnimates(type, args) {
+		let aniObj = this.currentStepAnimates[this.next]
+		let styles = {}
+		if (!aniObj) {
+			styles = {
+				styles: {},
+				config: {}
+			}
+		} else {
+			styles = aniObj
+		}
+		if (animateTypes1.includes(type)) {
+			if (!styles.styles.transform) {
+				styles.styles.transform = ''
+			}
+			let unit = ''
+			if(type === 'rotate'){
+				unit = 'deg'
+			}
+			styles.styles.transform += `${type}(${args+unit}) `
+		} else {
+			styles.styles[type] = `${args}`
+		}
+		this.currentStepAnimates[this.next] = styles
+	}
+	_animateRun(styles = {}, config = {}) {
+		let ref = this.$.$refs['ani'].ref
+		if (!ref) return
+		return new Promise((resolve, reject) => {
+			nvueAnimation.transition(ref, {
+				styles,
+				...config
+			}, res => {
+				resolve()
+			})
+		})
+	}
+
+	_nvueNextAnimate(animates, step = 0, fn) {
+		let obj = animates[step]
+		if (obj) {
+			let {
+				styles,
+				config
+			} = obj
+			this._animateRun(styles, config).then(() => {
+				step += 1
+				this._nvueNextAnimate(animates, step, fn)
+			})
+		} else {
+			this.currentStepAnimates = {}
+			typeof fn === 'function' && fn()
+			this.isEnd = true
+		}
+	}
+
+	step(config = {}) {
+		// #ifndef APP-NVUE
+		this.animation.step(config)
+		// #endif
+		// #ifdef APP-NVUE
+		this.currentStepAnimates[this.next].config = Object.assign({}, this.options, config)
+		this.currentStepAnimates[this.next].styles.transformOrigin = this.currentStepAnimates[this.next].config.transformOrigin
+		this.next++
+		// #endif
+		return this
+	}
+
+	run(fn) {
+		// #ifndef APP-NVUE
+		this.$.animationData = this.animation.export()
+		this.$.timer = setTimeout(() => {
+			typeof fn === 'function' && fn()
+		}, this.$.durationTime)
+		// #endif
+		// #ifdef APP-NVUE
+		this.isEnd = false
+		let ref = this.$.$refs['ani'] && this.$.$refs['ani'].ref
+		if(!ref) return
+		this._nvueNextAnimate(this.currentStepAnimates, 0, fn)
+		this.next = 0
+		// #endif
+	}
+}
+
+
+const animateTypes1 = ['matrix', 'matrix3d', 'rotate', 'rotate3d', 'rotateX', 'rotateY', 'rotateZ', 'scale', 'scale3d',
+	'scaleX', 'scaleY', 'scaleZ', 'skew', 'skewX', 'skewY', 'translate', 'translate3d', 'translateX', 'translateY',
+	'translateZ'
+]
+const animateTypes2 = ['opacity', 'backgroundColor']
+const animateTypes3 = ['width', 'height', 'left', 'right', 'top', 'bottom']
+animateTypes1.concat(animateTypes2, animateTypes3).forEach(type => {
+	MPAnimation.prototype[type] = function(...args) {
+		// #ifndef APP-NVUE
+		this.animation[type](...args)
+		// #endif
+		// #ifdef APP-NVUE
+		this._nvuePushAnimates(type, args)
+		// #endif
+		return this
+	}
+})
+
+export function createAnimation(option, _this) {
+	if(!_this) return
+	clearTimeout(_this.timer)
+	return new MPAnimation(option, _this)
+}
diff --git a/uni_modules/uni-transition/components/uni-transition/uni-transition.vue b/uni_modules/uni-transition/components/uni-transition/uni-transition.vue
new file mode 100644
index 0000000..bfbba93
--- /dev/null
+++ b/uni_modules/uni-transition/components/uni-transition/uni-transition.vue
@@ -0,0 +1,286 @@
+<template>
+  <!-- #ifndef APP-NVUE -->
+  <view v-show="isShow" ref="ani" :animation="animationData" :class="customClass" :style="transformStyles" @click="onClick"><slot></slot></view>
+  <!-- #endif -->
+  <!-- #ifdef APP-NVUE -->
+  <view v-if="isShow" ref="ani" :animation="animationData" :class="customClass" :style="transformStyles" @click="onClick"><slot></slot></view>
+  <!-- #endif -->
+</template>
+
+<script>
+import { createAnimation } from './createAnimation'
+
+/**
+ * Transition ������������
+ * @description ������������������������
+ * @tutorial https://ext.dcloud.net.cn/plugin?id=985
+ * @property {Boolean} show = [false|true] ���������������������������
+ * @property {Array|String} modeClass = [fade|slide-top|slide-right|slide-bottom|slide-left|zoom-in|zoom-out] ������������������
+ *  @value fade ������������������
+ *  @value slide-top ������������������
+ *  @value slide-right ������������������
+ *  @value slide-bottom ������������������
+ *  @value slide-left ������������������
+ *  @value zoom-in ������������������
+ *  @value zoom-out ������������������
+ * @property {Number} duration ������������������������
+ * @property {Object} styles ������������������ css ���������������������-������������������������������������������������������`backgroundColor:red`
+ */
+export default {
+	name: 'uniTransition',
+	emits:['click','change'],
+	props: {
+		show: {
+			type: Boolean,
+			default: false
+		},
+		modeClass: {
+			type: [Array, String],
+			default() {
+				return 'fade'
+			}
+		},
+		duration: {
+			type: Number,
+			default: 300
+		},
+		styles: {
+			type: Object,
+			default() {
+				return {}
+			}
+		},
+		customClass:{
+			type: String,
+			default: ''
+		},
+		onceRender:{
+			type:Boolean,
+			default:false
+		},
+	},
+	data() {
+		return {
+			isShow: false,
+			transform: '',
+			opacity: 1,
+			animationData: {},
+			durationTime: 300,
+			config: {}
+		}
+	},
+	watch: {
+		show: {
+			handler(newVal) {
+				if (newVal) {
+					this.open()
+				} else {
+					// ��������������������� close,������������������
+					if (this.isShow) {
+						this.close()
+					}
+				}
+			},
+			immediate: true
+		}
+	},
+	computed: {
+		// ������������������
+		stylesObject() {
+			let styles = {
+				...this.styles,
+				'transition-duration': this.duration / 1000 + 's'
+			}
+			let transform = ''
+			for (let i in styles) {
+				let line = this.toLine(i)
+				transform += line + ':' + styles[i] + ';'
+			}
+			return transform
+		},
+		// ���������������������
+		transformStyles() {
+			return 'transform:' + this.transform + ';' + 'opacity:' + this.opacity + ';' + this.stylesObject
+		}
+	},
+	created() {
+		// ������������������
+		this.config = {
+			duration: this.duration,
+			timingFunction: 'ease',
+			transformOrigin: '50% 50%',
+			delay: 0
+		}
+		this.durationTime = this.duration
+	},
+	methods: {
+		/**
+		 *  ref ������ ���������������
+		 */
+		init(obj = {}) {
+			if (obj.duration) {
+				this.durationTime = obj.duration
+			}
+			this.animation = createAnimation(Object.assign(this.config, obj),this)
+		},
+		/**
+		 * ������������������������
+		 */
+		onClick() {
+			this.$emit('click', {
+				detail: this.isShow
+			})
+		},
+		/**
+		 * ref ������ ������������
+		 * @param {Object} obj
+		 */
+		step(obj, config = {}) {
+			if (!this.animation) return
+			for (let i in obj) {
+				try {
+					if(typeof obj[i] === 'object'){
+						this.animation[i](...obj[i])
+					}else{
+						this.animation[i](obj[i])
+					}
+				} catch (e) {
+					console.error(`������ ${i} ���������`)
+				}
+			}
+			this.animation.step(config)
+			return this
+		},
+		/**
+		 *  ref ������ ������������
+		 */
+		run(fn) {
+			if (!this.animation) return
+			this.animation.run(fn)
+		},
+		// ������������������
+		open() {
+			clearTimeout(this.timer)
+			this.transform = ''
+			this.isShow = true
+			let { opacity, transform } = this.styleInit(false)
+			if (typeof opacity !== 'undefined') {
+				this.opacity = opacity
+			}
+			this.transform = transform
+			// ��������������������������������������������������������������� nextTick ������������ wx ������������������
+			this.$nextTick(() => {
+				// TODO ���������������������������������������������������������������������������������
+				this.timer = setTimeout(() => {
+					this.animation = createAnimation(this.config, this)
+					this.tranfromInit(false).step()
+					this.animation.run()
+					this.$emit('change', {
+						detail: this.isShow
+					})
+				}, 20)
+			})
+		},
+		// ������������������
+		close(type) {
+			if (!this.animation) return
+			this.tranfromInit(true)
+				.step()
+				.run(() => {
+					this.isShow = false
+					this.animationData = null
+					this.animation = null
+					let { opacity, transform } = this.styleInit(false)
+					this.opacity = opacity || 1
+					this.transform = transform
+					this.$emit('change', {
+						detail: this.isShow
+					})
+				})
+		},
+		// ������������������������������������
+		styleInit(type) {
+			let styles = {
+				transform: ''
+			}
+			let buildStyle = (type, mode) => {
+				if (mode === 'fade') {
+					styles.opacity = this.animationType(type)[mode]
+				} else {
+					styles.transform += this.animationType(type)[mode] + ' '
+				}
+			}
+			if (typeof this.modeClass === 'string') {
+				buildStyle(type, this.modeClass)
+			} else {
+				this.modeClass.forEach(mode => {
+					buildStyle(type, mode)
+				})
+			}
+			return styles
+		},
+		// ������������������������
+		tranfromInit(type) {
+			let buildTranfrom = (type, mode) => {
+				let aniNum = null
+				if (mode === 'fade') {
+					aniNum = type ? 0 : 1
+				} else {
+					aniNum = type ? '-100%' : '0'
+					if (mode === 'zoom-in') {
+						aniNum = type ? 0.8 : 1
+					}
+					if (mode === 'zoom-out') {
+						aniNum = type ? 1.2 : 1
+					}
+					if (mode === 'slide-right') {
+						aniNum = type ? '100%' : '0'
+					}
+					if (mode === 'slide-bottom') {
+						aniNum = type ? '100%' : '0'
+					}
+				}
+				this.animation[this.animationMode()[mode]](aniNum)
+			}
+			if (typeof this.modeClass === 'string') {
+				buildTranfrom(type, this.modeClass)
+			} else {
+				this.modeClass.forEach(mode => {
+					buildTranfrom(type, mode)
+				})
+			}
+
+			return this.animation
+		},
+		animationType(type) {
+			return {
+				fade: type ? 1 : 0,
+				'slide-top': `translateY(${type ? '0' : '-100%'})`,
+				'slide-right': `translateX(${type ? '0' : '100%'})`,
+				'slide-bottom': `translateY(${type ? '0' : '100%'})`,
+				'slide-left': `translateX(${type ? '0' : '-100%'})`,
+				'zoom-in': `scaleX(${type ? 1 : 0.8}) scaleY(${type ? 1 : 0.8})`,
+				'zoom-out': `scaleX(${type ? 1 : 1.2}) scaleY(${type ? 1 : 1.2})`
+			}
+		},
+		// ���������������������������������������������
+		animationMode() {
+			return {
+				fade: 'opacity',
+				'slide-top': 'translateY',
+				'slide-right': 'translateX',
+				'slide-bottom': 'translateY',
+				'slide-left': 'translateX',
+				'zoom-in': 'scale',
+				'zoom-out': 'scale'
+			}
+		},
+		// ������������������
+		toLine(name) {
+			return name.replace(/([A-Z])/g, '-$1').toLowerCase()
+		}
+	}
+}
+</script>
+
+<style></style>
diff --git a/uni_modules/uni-transition/package.json b/uni_modules/uni-transition/package.json
new file mode 100644
index 0000000..ea995a2
--- /dev/null
+++ b/uni_modules/uni-transition/package.json
@@ -0,0 +1,84 @@
+{
+  "id": "uni-transition",
+  "displayName": "uni-transition ������������",
+  "version": "1.3.2",
+  "description": "���������������������������",
+  "keywords": [
+    "uni-ui",
+    "uniui",
+    "������",
+    "������",
+    "������������"
+],
+  "repository": "https://github.com/dcloudio/uni-ui",
+  "engines": {
+    "HBuilderX": ""
+  },
+  "directories": {
+    "example": "../../temps/example_temps"
+  },
+"dcloudext": {
+    "sale": {
+      "regular": {
+        "price": "0.00"
+      },
+      "sourcecode": {
+        "price": "0.00"
+      }
+    },
+    "contact": {
+      "qq": ""
+    },
+    "declaration": {
+      "ads": "���",
+      "data": "���",
+      "permissions": "���"
+    },
+    "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui",
+    "type": "component-vue"
+  },
+  "uni_modules": {
+    "dependencies": ["uni-scss"],
+    "encrypt": [],
+    "platforms": {
+      "cloud": {
+        "tcb": "y",
+        "aliyun": "y"
+      },
+      "client": {
+        "App": {
+          "app-vue": "y",
+          "app-nvue": "y"
+        },
+        "H5-mobile": {
+          "Safari": "y",
+          "Android Browser": "y",
+          "���������������(Android)": "y",
+          "QQ���������(Android)": "y"
+        },
+        "H5-pc": {
+          "Chrome": "y",
+          "IE": "y",
+          "Edge": "y",
+          "Firefox": "y",
+          "Safari": "y"
+        },
+        "���������": {
+          "������": "y",
+          "������": "y",
+          "������": "y",
+          "������������": "y",
+          "QQ": "y"
+        },
+        "���������": {
+          "������": "u",
+          "������": "u"
+        },
+        "Vue": {
+            "vue2": "y",
+            "vue3": "y"
+        }
+      }
+    }
+  }
+}
\ No newline at end of file
diff --git a/uni_modules/uni-transition/readme.md b/uni_modules/uni-transition/readme.md
new file mode 100644
index 0000000..2f8a77e
--- /dev/null
+++ b/uni_modules/uni-transition/readme.md
@@ -0,0 +1,11 @@
+
+
+## Transition ������������
+> **������������uni-transition**
+> ������������ `uTransition`
+
+
+������������������
+
+### [������������](https://uniapp.dcloud.io/component/uniui/uni-transition)
+#### ������������������������������������������������uni-ui������������������������������������ uni-ui ������������871950839 
\ No newline at end of file
diff --git a/uni_modules/ws-wx-privacy/changelog.md b/uni_modules/ws-wx-privacy/changelog.md
new file mode 100644
index 0000000..cd77175
--- /dev/null
+++ b/uni_modules/ws-wx-privacy/changelog.md
@@ -0,0 +1,22 @@
+## 1.0.10���2023-09-12���
+������������������������������������������������������������������
+## 1.0.9���2023-09-11���
+���������������������������������������
+## 1.0.8���2023-09-11���
+������������������������������������
+## 1.0.7���2023-09-08���
+������������������
+## 1.0.6���2023-09-07���
+������������������������������������������disagreeEnabled���false������������������������������������disagreePromptText���������
+## 1.0.5���2023-09-05���
+## README������������������������������
+## 1.0.4���2023-09-02���
+������������������������������������������������������
+## 1.0.3���2023-09-01���
+# ��������� ������������������������������������������������������������������������������
+## 1.0.2���2023-09-01���
+������������������������������������������������
+## 1.0.1���2023-08-31���
+������������������������������������������������������������������������������������������
+## 1.0.0���2023-08-30���
+������������������������������������vue2���vue3
diff --git a/uni_modules/ws-wx-privacy/components/ws-wx-privacy/util.js b/uni_modules/ws-wx-privacy/components/ws-wx-privacy/util.js
new file mode 100644
index 0000000..e6918ea
--- /dev/null
+++ b/uni_modules/ws-wx-privacy/components/ws-wx-privacy/util.js
@@ -0,0 +1,51 @@
+/**
+ * ���������������������������
+ * @returns ������������
+ */
+export function getContext() {
+	// eslint-disable-next-line no-undef
+	const pages = getCurrentPages()
+	return pages[pages.length - 1]
+}
+
+/**
+ * ������������������������������������
+ * @param context ��������������������������������������������������������� this ���������������
+ * @param selector ������������������������
+ */
+export function getComponent(context, selector ) {
+	let component = null
+	// #ifdef H5
+	context.$children.forEach((child) => {
+		if (`#${child.$attrs.id}` === selector) {
+			component = child
+		} else if (child.$children && child.$children.length) {
+			if (getComponent(child, selector)) {
+				component = getComponent(child, selector)
+			}
+		}
+		if (component) {
+			return component
+		}
+	})
+	// #endif
+	// #ifdef MP-WEIXIN
+	component = context.selectComponent && context.selectComponent(selector) && context.selectComponent(selector).$vm
+	// #endif
+
+	// #ifdef MP-ALIPAY
+	const alipay = context.$children ? context.$children : context.$vm && context.$vm.$children ? context.$vm
+		.$children : []
+	component = alipay.find((component) => {
+		return `#${component.$scope.props.id}` === selector
+	})
+	// #endif
+	// #ifdef APP-PLUS
+	const app = context.$children ? context.$children : context.$vm && context.$vm.$children ? context.$vm.$children :
+	[]
+	component = app.find((component) => {
+		return `#${component.$attrs.id}` === selector
+	})
+	// #endif
+	return component
+}
\ No newline at end of file
diff --git a/uni_modules/ws-wx-privacy/components/ws-wx-privacy/ws-wx-privacy.vue b/uni_modules/ws-wx-privacy/components/ws-wx-privacy/ws-wx-privacy.vue
new file mode 100644
index 0000000..2b9dcd2
--- /dev/null
+++ b/uni_modules/ws-wx-privacy/components/ws-wx-privacy/ws-wx-privacy.vue
@@ -0,0 +1,287 @@
+<template>
+	<uni-popup id="privacy" type="center" ref="privacyPopup" :maskClick="false">
+		<view class="ws-privacy-popup" :style="rootStyle">
+			<view class="ws-privacy-popup__header">
+				<!--������-->
+				<view class="ws-picker__title">{{ title }}</view>
+			</view>
+			<view class="ws-privacy-popup__container">
+				<text>{{ desc }}</text>
+				<text class="ws-privacy-popup__container-protocol" :style="protocolStyle"
+					@click="openPrivacyContract">{{ privacyContractName||protocol }}</text>
+				<text>{{ subDesc }}</text>
+			</view>
+			<view class="ws-privacy-popup__footer">
+				<button class="is-agree" :style="agreeStyle" id="agree-btn" open-type="agreePrivacyAuthorization"
+					@agreeprivacyauthorization="handleAgree">
+					{{agreeText}}
+				</button>
+				<button class="is-disagree" id="disagree-btn" @click="handleDisagree">
+					{{disagreeText}}
+				</button>
+			</view>
+		</view>
+	</uni-popup>
+</template>
+<script>
+	import {
+		getContext,
+		getComponent
+	} from './util'
+	const privacyResolves = new Set() // onNeedPrivacyAuthorization���reslove
+
+	let privacyHandler = null
+	// ������������
+	if (uni.onNeedPrivacyAuthorization) {
+		uni.onNeedPrivacyAuthorization((resolve) => {
+			if (typeof privacyHandler === 'function') {
+				privacyHandler(resolve)
+			}
+		})
+	}
+
+	export default {
+		name: 'wsWxPrivacy',
+		emits: ['disagree', 'agree'],
+		props: {
+			// ������
+			title: {
+				type: String,
+				default: '������������������������'
+			},
+			// ������
+			desc: {
+				type: String,
+				default: '������������������������������������������������������������������������������������'
+			},
+			// ���������������������������������
+			protocol: {
+				type: String,
+				default: '������������������������������'
+			},
+			// ������������������������������������������������������������getPrivacySetting���������������
+			enableAutoProtocol: {
+				type: Boolean,
+				default: false, // ������������������������������������������
+			},
+			// ���������
+			subDesc: {
+				type: String,
+				default: '���������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������'
+			},
+			/**
+			 * ���������������������������������������������������������
+			 * ��������������� true���������������������������������������������������������
+			 * ��������������� false������������������������������������������������������������������������������
+			 * ��������� true
+			 */
+			disagreeEnabled: {
+				type: Boolean,
+				default: true, // ���������������������
+			},
+			/**
+			 * ���������������������������������������������
+			 */
+			disagreePromptText: {
+				type: String,
+				default: '���������������������������������������', // ������������������
+			},
+			// ������������������
+			disagreeText: {
+				type: String,
+				default: '���������'
+			},
+			// ������������������
+			agreeText: {
+				type: String,
+				default: '���������������'
+			},
+			// ���������������������
+			bgColor: {
+				type: String,
+				default: ''
+			},
+			// ���������������������������������������������������������������������������
+			themeColor: {
+				type: String,
+				default: ''
+			}
+		},
+		data() {
+			return {
+				privacyContractName: '',
+			}
+		},
+		computed: {
+			rootStyle() {
+				if (this.bgColor) {
+					return `background:${this.bgColor}`
+				} else {
+					return ''
+				}
+			},
+			protocolStyle() {
+				if (this.themeColor) {
+					return `color:${this.themeColor}`
+				} else {
+					return ''
+				}
+			},
+			agreeStyle() {
+				if (this.themeColor) {
+					return `background:${this.themeColor}`
+				} else {
+					return ''
+				}
+			}
+		},
+		created() {
+			privacyHandler = (resolve) => {
+				const context = getContext()
+				const privacyPopup = getComponent(context, '#privacy-popup')
+				if (privacyPopup) {
+					const privacy = getComponent(privacyPopup, '#privacy')
+					if (privacy && privacy.open) {
+						privacy.open()
+					}
+				}
+				privacyResolves.add(resolve)
+			}
+			if (this.enableAutoProtocol && uni.getPrivacySetting) {
+				uni.getPrivacySetting({
+					success: res => {
+						if (res.privacyContractName) {
+							this.privacyContractName = res.privacyContractName
+						}
+					},
+					fail: () => {},
+					complete: () => {}
+				})
+			}
+		},
+		methods: {
+			/**
+			 * ������������������
+			 */
+			openPrivacyContract() {
+				wx.openPrivacyContract({
+					success: (res) => {
+						console.log('openPrivacyContract success')
+					},
+					fail: (res) => {
+						console.error('openPrivacyContract fail', res)
+					}
+				})
+			},
+
+			/**
+			 * ������������������
+			 */
+			handleDisagree() {
+				if (this.disagreeEnabled) {
+					this.$refs.privacyPopup.close()
+					privacyResolves.forEach((resolve) => {
+						resolve({
+							event: 'disagree'
+						})
+					})
+					privacyResolves.clear()
+					this.$emit('disagree')
+				} else {
+					uni.showToast({
+						icon: 'none',
+						title: this.disagreePromptText
+					})
+				}
+
+			},
+
+			/**
+			 * ������������������
+			 */
+			handleAgree() {
+				this.$refs.privacyPopup.close()
+				privacyResolves.forEach((resolve) => {
+					resolve({
+						event: 'agree',
+						buttonId: 'agree-btn'
+					})
+				})
+				privacyResolves.clear()
+				this.$emit('agree')
+			}
+		}
+	}
+</script>
+<style lang="scss" scoped>
+	.ws-privacy-popup {
+		padding: 48rpx;
+		box-sizing: border-box;
+		overflow: hidden;
+		width: 560rpx;
+		background: linear-gradient(180deg, #e5edff 0%, #ffffff 100%);
+		border-radius: 24rpx;
+
+		&__header {
+			display: flex;
+			align-items: center;
+			justify-content: center;
+			width: 100%;
+			height: 52rpx;
+			font-size: 36rpx;
+			font-family: PingFangSC-Medium, PingFang SC;
+			font-weight: 550;
+			color: #1a1a1a;
+			line-height: 52rpx;
+			margin-bottom: 48rpx;
+		}
+
+		&__container {
+			width: 100%;
+			box-sizing: border-box;
+			font-size: 28rpx;
+			font-family: PingFangSC-Regular, PingFang SC;
+			font-weight: 400;
+			color: #333333;
+			line-height: 48rpx;
+			margin-bottom: 48rpx;
+
+			&-protocol {
+				font-weight: 550;
+				color: #4D80F0;
+			}
+		}
+
+		&__footer {
+			display: flex;
+			flex-direction: column;
+
+			.is-disagree,
+			.is-agree {
+				width: 100%;
+				height: 88rpx;
+				background: #ffffff;
+				border-radius: 44rpx;
+				font-size: 32rpx;
+				font-family: PingFangSC-Regular, PingFang SC;
+				font-weight: 400;
+				color: #666666;
+			}
+
+			.is-agree {
+				background: #4D80F0;
+				color: #ffffff;
+				margin-bottom: 18rpx;
+			}
+
+			button {
+				border: none;
+				outline: none;
+
+				&::after {
+					border: none;
+				}
+			}
+		}
+	}
+</style>
\ No newline at end of file
diff --git a/uni_modules/ws-wx-privacy/package.json b/uni_modules/ws-wx-privacy/package.json
new file mode 100644
index 0000000..8289251
--- /dev/null
+++ b/uni_modules/ws-wx-privacy/package.json
@@ -0,0 +1,85 @@
+{
+  "id": "ws-wx-privacy",
+  "displayName": "ws-wx-privacy ��������������������������� ���������������������",
+  "version": "1.0.10",
+  "description": "��������������������������� ������������������������������vue2���vue3��������������������������������� ws-wx-privacy���������������������������������������������������",
+  "keywords": [
+    "���������������",
+    "������������",
+    "������������������",
+    "������������",
+    "������"
+],
+  "repository": "",
+  "engines": {
+    "HBuilderX": "^3.8.6"
+  },
+  "dcloudext": {
+    "type": "component-vue",
+    "sale": {
+      "regular": {
+        "price": "0.00"
+      },
+      "sourcecode": {
+        "price": "0.00"
+      }
+    },
+    "contact": {
+      "qq": ""
+    },
+    "declaration": {
+      "ads": "���",
+      "data": "���������������������������",
+      "permissions": "���"
+    },
+    "npmurl": ""
+  },
+  "uni_modules": {
+    "dependencies": ["uni-popup"],
+    "encrypt": [],
+    "platforms": {
+      "cloud": {
+        "tcb": "y",
+        "aliyun": "y"
+      },
+      "client": {
+        "Vue": {
+          "vue2": "y",
+          "vue3": "y"
+        },
+        "App": {
+          "app-vue": "n",
+          "app-nvue": "n"
+        },
+        "H5-mobile": {
+          "Safari": "n",
+          "Android Browser": "n",
+          "���������������(Android)": "n",
+          "QQ���������(Android)": "n"
+        },
+        "H5-pc": {
+          "Chrome": "n",
+          "IE": "n",
+          "Edge": "n",
+          "Firefox": "n",
+          "Safari": "n"
+        },
+        "���������": {
+          "������": "y",
+          "������": "n",
+          "������": "n",
+          "������������": "n",
+          "QQ": "n",
+          "������": "n",
+          "������": "n",
+          "������": "n",
+          "������": "n"
+        },
+        "���������": {
+          "������": "n",
+          "������": "n"
+        }
+      }
+    }
+  }
+}
\ No newline at end of file
diff --git a/uni_modules/ws-wx-privacy/readme.md b/uni_modules/ws-wx-privacy/readme.md
new file mode 100644
index 0000000..a84483e
--- /dev/null
+++ b/uni_modules/ws-wx-privacy/readme.md
@@ -0,0 +1,122 @@
+# ws-wx-privacy  ������������������������
+
+���������������������������������������������������[������������������������������������������������](https://developers.weixin.qq.com/community/develop/doc/00042e3ef54940ce8520e38db61801?blockType=1&page=1#comment-list)
+
+`wsWxPrivacy` ���������������������������������������������������������������������������������������������������
+
+# ��������� ������������������������������������������������������������������������������
+
+### ������������  
+1. ���������HbuilderX������������������������������`uni-popup`������������������������������  
+2. ���������������������������`wx.requirePrivacyAuthorize`������������������������������[���������������������������������������](https://developers.weixin.qq.com/miniprogram/dev/framework/user-privacy/PrivacyAuthorize.html)
+3. popup���������������������������������������������������������������������������������������������������`util.js`������������������������������������������ref���������������this������������������������������������������
+4. ������demo���������������vue3������������������������������
+
+### ���������������������������������������������������������������������
+������������������������������������������������������������������������������������������������������������������������������������
+
+#### 1.������������������������������(������) 
+���������������������������������������������������������������������[������������������](https://developers.weixin.qq.com/miniprogram/dev/framework/user-privacy/miniprogram-intro.html)���������������������������������`������������������������`������������������������������������������������������������������������
+
+`���������������������������������������������������������������������������������������������������������������������������������������������������������������������������������`
+
+`���������������������������������������������������������������������������������������������������!������������!������������!`
+
+#### 2.������������������__usePrivacyCheck__ ������������
+������ [���������������������������������������](https://developers.weixin.qq.com/miniprogram/dev/framework/user-privacy/PrivacyAuthorize.html)������������
+
+������ `getPrivacySetting`���`onNeedPrivacyAuthorization`���`requirePrivacyAuthorize` ���������������������������������������������������������
+
+- ��� 2023 ��� 9 ��� 15 ��������������� app.json ��������� `"__usePrivacyCheck__": true` ������������������������������������������������������������������ false ������������������
+
+- ��� 2023 ��� 9 ��� 15 ������������������ app.json ������������������ **usePrivacyCheck**������������������������������������
+
+���������������`uni-app`��������������������� 2023 ��� 9 ��� 15 ���������������������������������������������`manifest.json`������`mp-weixin`���������`"__usePrivacyCheck__": true`
+
+#### 3.���������������������������������������������
+������������������������3.0.0������������������������:  
+���������������������->������->������������->���������������
+
+#### 4.������������������������������������������������������������
+������������getPrivacySetting������������������������������������������������������������������������������������������������������������������
+
+
+### Props
+
+| ������				| ������		| ���������							| ������																																									|
+|------------		|--------	|----------------------------------	|------------------------------------------------------------------------------------------																				|
+| title				| String	| ������������������������					| ���������������																																							|
+| desc				| String	| ���������������������������...				| ���������������																																							|
+| protocol			| String	| ������������������������					| ������������������������������																																					|
+| subDesc			| String	| ���������������������������������...			| ���������������������������������������������������������																																|
+| disagreeEnabled	| Boolean	| true								| ��������������������������������������������������������������������������������������������������� true������������������������������������������������������������������������ false������������������������������������������������������������������������������	|
+| disagreePromptText| String	| ���������������������������������������		| ���������������������������������������																																		|
+| bgColor           | String   |  -                                | ������������������������                                                                                                                                   |
+| themeColor        | String   |  -                               | ������������������������������������������������������������������������������                                                                                              |
+
+### Events
+
+| ������      | ������                                   | ������                                                                                   |
+|-----------|----------------------------------------|----------------------------------------------------------------------------------------|
+| disagree  | ���������                                 | ������������������������������������������������������                                                       |
+| agree     | ���������                                 | ���������������������������������������������������                                                       |
+
+
+### ������������
+������������������������������������[uni-modules ������](https://uniapp.dcloud.net.cn/plugin/uni_modules.html#uni-modules)  
+������hbuildX������������������������������������������import���
+
+```vue
+<template>
+  <view>
+  <!-- #ifdef MP-WEIXIN -->
+  <ws-wx-privacy id="privacy-popup"></ws-wx-privacy>
+  <!-- #endif -->
+  </view>
+</template>
+<script>
+
+export default {
+  components: {},
+  methods: {
+    handleDisagree() {
+      // ������������������������������������������
+    },
+    handleAgree() {
+      // ���������������������������������������
+    }
+  }
+}
+</script>
+```
+
+������������������������������������������������������������������������������������������������������������������`id="privacy-popup"`������������������������������������������������������������������������this������������������������
+
+## ������������
+```
+1. ������������������������������������
+2. ���������������������������������������������������������������
+3. ���������������������������������������������������������������������������������������������
+```
+
+## ������������
+### 1.������������������������
+#### ������������������"���������������������������������������������������������������������"������������������������������������������������������������������API���������������������������������
+#### ���������������������������������������������������  
+#### ������������������getPrivacySetting���������������������������������������
+
+### 2.���������������������������
+#### ���������������������������vue3���������������������������������vue3���������  
+
+### 3.������������������vue2  
+#### ������
+
+### 4.chooseImage������������������������������������������������
+#### ������������������������1���������������������������������������������������������API
+
+### 5.������������������������������������������������  
+#### ���[������������������](https://developers.weixin.qq.com/miniprogram/dev/framework/user-privacy/miniprogram-intro.html)���������������������API���������uni.chooseImage������������������������������������������������	���
+ 
+ 
+## Vue3������������������������
+������������������[wot-design-uni](https://ext.dcloud.net.cn/plugin?id=13889)������������������������������������������������������������������50+���������
\ No newline at end of file
diff --git a/utils/websoket.js b/utils/websoket.js
new file mode 100644
index 0000000..841f339
--- /dev/null
+++ b/utils/websoket.js
@@ -0,0 +1,91 @@
+class websocketUtil {
+	constructor(url, time) {
+		this.is_open_socket = false //������������������
+		this.url = url //������
+		this.data = null
+		//������������
+		this.timeout = time //���������������������
+		this.heartbeatInterval = null //���������������������������������
+		this.reconnectTimeOut = null //������������������������������
+		try {
+			return this.connectSocketInit()
+		} catch (e) {
+			console.log('catch');
+			this.is_open_socket = false
+			this.reconnect();
+		}
+	}
+	// ���������������������������������websocket������������������������������������
+	connectSocketInit() {
+		this.socketTask = uni.connectSocket({
+			url: this.url,
+			success: () => {
+				console.log("���������������websocket���...");
+				// ������������
+				return this.socketTask
+			},
+		});
+		this.socketTask.onOpen((res) => {
+			console.log("WebSocket���������������");
+			clearTimeout(this.reconnectTimeOut)
+			clearTimeout(this.heartbeatInterval)
+			this.is_open_socket = true;
+			this.start();
+			// ��������������������������������� ���������������������������
+			this.socketTask.onMessage((res) => {
+				console.log(res.data)
+			});
+		})
+		// ������������������������������������������������������������������������������������������������������onclose������������������������������������������������������������
+		// uni.onSocketError((res) => {
+		// 	console.log('WebSocket���������������������������������');
+		// 	this.is_open_socket = false;
+		// 	this.reconnect();
+		// });
+		// ���������������������������������socket���������������������
+		this.socketTask.onClose(() => {
+			console.log("������������������")
+			this.is_open_socket = false;
+			this.reconnect();
+		})
+	}
+	//������������
+	send(value) {
+		// ��������������������������������� ���������������������������������
+		this.socketTask.send({
+			data: value,
+			async success() {
+				console.log("������������������");
+			},
+		});
+	}
+	//������������������
+	start() {
+		this.heartbeatInterval = setTimeout(() => {
+			this.data = {
+				value: "������������",
+				method: "������������"
+			}
+			console.log(this.data)
+			this.send(JSON.stringify(this.data));
+		}, this.timeout)
+	}
+	//������������
+	reconnect() {
+		//������������������
+		clearInterval(this.heartbeatInterval)
+		//���������������������������������������������
+		if (!this.is_open_socket) {
+			this.reconnectTimeOut = setTimeout(() => {
+				this.connectSocketInit();
+			}, 3000)
+		}
+	}
+	//������������������
+	getMessage(callback) {
+		this.socketTask.onMessage((res) => {
+			return callback(res)
+		})
+	}
+}
+module.exports = websocketUtil
\ No newline at end of file

--
Gitblit v1.8.0