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