更新大理市民卡app
diff --git a/pages/sub_basic/forgetPwd/index.vue b/pages/sub_basic/forgetPwd/index.vue
new file mode 100644
index 0000000..523f916
--- /dev/null
+++ b/pages/sub_basic/forgetPwd/index.vue
@@ -0,0 +1,224 @@
+<template>
+	<view class="register" @touchmove.stop.prevent="moveHandle">
+		<!-- #ifndef MP-WEIXIN -->
+		 <u-navbar title="忘记密码" :border-bottom="false" :is-back="false"></u-navbar>
+		 <!-- #endif -->
+		<view class="register-con">
+			<view class="register-con-logo">
+				<u-image src="/static/images/login/logo.png" width="300rpx" mode="widthFix"></u-image>
+			</view>
+			<view class="register-con-form">
+				<u-field v-model="tel" placeholder="请输入手机号" label-width="50" maxlength="11" type="number" clear-size="40">
+					<u-icon slot="icon" name="shouji" custom-prefix="custom-icon" color="#999999"></u-icon>
+				</u-field>
+				<u-field v-model="code" placeholder="请输入验证码" label-width="50" maxlength="6" type="number" clear-size="40">
+					<u-icon slot="icon" name="code" custom-prefix="custom-icon" color="#999999"></u-icon>
+					<u-button slot="right" @click="getCode" :custom-style="btn" size="mini" :disabled="isChecked">{{codeText}}</u-button>
+				</u-field>
+				<u-field v-model="pwd" icon="lock-fill" placeholder="请输入新的密码" label-width="50" icon-color="#999999" :password="true"
+				 maxlength="12" type="number" clear-size="40"></u-field>
+			</view>
+			<u-button @click="changePwd" :custom-style="registerConBtn">修改密码</u-button>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				codeText: "获取验证码",
+				pwd: "",
+				tel: "",
+				code: "",
+				isChecked: false,
+				timer: "",
+				registerConBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				},
+				btn:{
+					color: '#2FA8E1',
+					backgroundColor: '#FFFFFF',
+					borderColor:'#2FA8E1',
+					borderWidth: '1rpx',
+					borderStyle: 'solid',
+					fontFamily: "PingFang-SC-Regular"
+				}
+			}
+		},
+		methods: {
+			moveHandle(){
+				return
+			},
+			getCode() {
+				let that = this
+				let tel = that.tel
+				if (tel == "") {
+					uni.showToast({
+						title: "请输入正确手机号",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				uni.removeStorageSync('token')
+				that.$u.post('/i/code', {
+					phone: tel,
+					"type":"find"
+				}).then(res => {
+					uni.showToast({
+						title: res.msg,
+						icon: "none",
+						duration: 800
+					})
+					let i = 60
+					that.isChecked = true
+					that.timer = setInterval(() => {
+						if (i != 0) {
+							i--
+							that.codeText = i + "s"
+						} else {
+							clearInterval(that.timer)
+							that.codeText = "重新获取"
+							that.isChecked = false
+						}
+					}, 1000)
+				})
+			},
+			async changePwd() {
+				let that = this
+				let {
+					tel,
+					pwd,
+					code
+				} = that
+				if (tel == "") {
+					uni.showToast({
+						title: "请输入正确手机号",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (code == "") {
+					uni.showToast({
+						title: "请输入验证码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (pwd == "") {
+					uni.showToast({
+						title: "请设置您的密码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				let param = {
+					phone: tel,
+					code: code,
+				}
+				let ret = await that.$u.post("/i/checkcode", param)
+				if (ret.code === 200) {
+					let {
+						randcode,
+						uid
+					} = ret
+					let params = {
+						"pwd": pwd,
+						"repwd": pwd,
+						"id": uid,
+						"random": randcode
+						// "id":"2c9b808573b4eff001740fccd23c63fc",
+						// "random":"r5m7anoef7ku5gdsz6o4gi2rkk5enf"
+					}
+					that.$u.post("/i/register", params).then((res) => {
+						uni.setStorageSync("token", res.token)
+						uni.setStorageSync("userid", res.userid)
+						uni.setStorageSync("tenantid", res.tenantid)
+						uni.setStorageSync("tokenexpire", res.expire)
+						uni.setStorageSync("tokentime", res.now)
+						uni.setStorageSync("signed", res.signed)
+						uni.setStorageSync("paypwdset", res.paypwdset)
+						uni.showToast({
+							title: "密码重置成功",
+							icon: "none",
+							duration: 800,
+							complete(res){
+								setTimeout(() => {
+									uni.reLaunch({
+										url:"/pages/sub_basic/login/index"
+									})
+								}, 1500)
+							}
+						})
+					})
+				}
+			}
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.btn {
+		border-radius: 50rpx;
+		width: 150rpx;
+		color: #2FA8E1;
+		border: 2rpx #2FA8E1 solid;
+		font-size: 25rpx;
+	}
+
+	.register {
+		width: 100vw;
+		font-family: "PingFang-SC-Medium";
+		background-color: #FFFFFF;
+		height: 100vh;
+
+		&-con {
+			padding: 30rpx;
+
+			&-title {
+				display: flex;
+				justify-content: space-between;
+				align-items: center;
+
+				text {
+					font-family: "PingFang-SC-Medium";
+					font-size: 32rpx;
+					color: #333333;
+				}
+			}
+
+			&-logo {
+				display: flex;
+				justify-content: center;
+				padding: 30rpx 0;
+				align-items: center;
+				text-align: center;
+			}
+
+			&-form {
+				width: 650rpx;
+				margin: auto;
+			}
+
+			&-btn {
+				background-color: #2FA8E1;
+				padding: 50rpx 0;
+				color: #FFFFFF;
+				width: 600rpx;
+				font-size: 30rpx;
+				margin-top: 100rpx;
+			}
+		}
+
+	}
+</style>
diff --git a/pages/sub_basic/login/index.vue b/pages/sub_basic/login/index.vue
new file mode 100644
index 0000000..7da6209
--- /dev/null
+++ b/pages/sub_basic/login/index.vue
@@ -0,0 +1,422 @@
+<template>
+	<view class="login" @touchmove.stop.prevent="moveHandle">
+		<!-- #ifndef MP-WEIXIN -->
+		<u-navbar title="登录" :border-bottom="false" :is-back="false"></u-navbar>
+		<!-- #endif -->
+		<view class="login-con">
+			<view class="login-con-logo">
+				<u-image src="/static/images/login/logo.png" width="300rpx" mode="widthFix"></u-image>
+			</view>
+			<view class="login-con-form">
+				<u-field v-model="tel" placeholder="请输入手机号" label-width="50" maxlength="11" type="number" clear-size="40">
+					<u-icon slot="icon" name="shouji" custom-prefix="custom-icon" color="#999999"></u-icon>
+				</u-field>
+				<u-field v-model="pwd" icon="lock-fill" placeholder="请输入密码" label-width="50" icon-color="#999999" maxlength="12"
+				 :password="true" type="text" clear-size="40"></u-field>
+				<view class="login-con-form-forget"><text @click="toUrl('/pages/sub_basic/forgetPwd/index')">忘记密码?</text></view>
+			</view>
+			<u-button @click="login" :custom-style="loginConBtn">登录</u-button>
+			<u-button @click="toUrl('/pages/sub_basic/register/index')" :custom-style="loginConBtnr">注册</u-button>
+			<view class="login-con-youke" @click="toIndex"><text>游客登陆</text></view>
+			<view class="login-con-footer">
+				<view class="login-con-footer-title"><text style="color: #CCCCCC;margin-right: 30rpx;">————</text> 其他登陆方式 <text
+					 style="color: #CCCCCC;margin-left: 30rpx;">————</text></view>
+				<view class="login-con-footer-icon">
+					<u-image src="/static/images/login/finge.png" width="50rpx" height="50rpx" mode="aspectFit" @click="fingerIn"></u-image>
+					<u-image src="/static/images/login/face.png" width="50rpx" height="50rpx" mode="aspectFit" @click="faceIn"></u-image>
+					<u-image src="/static/images/login/hands.png" width="50rpx" height="50rpx" mode="aspectFit" @click="handsIn"></u-image>
+				</view>
+			</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	const app = getApp()
+	export default {
+		data() {
+			return {
+				pwd: "",
+				tel: "",
+				loginConBtn: {
+					backgroundColor: ' #2FA8E1',
+					padding: '50rpx 0',
+					color: '#FFFFFF',
+					width: ' 600rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+				},
+				loginConBtnr: {
+					padding: '50rpx 0',
+					color: '#2FA8E1',
+					width: ' 600rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+					marginTop: '30rpx'
+				}
+			}
+		},
+		onLoad() {
+			let routes = getCurrentPages();
+			let tel = uni.getStorageSync("phone")
+			if (tel) {
+				this.tel = tel
+			}
+			
+		},
+		methods: {
+			moveHandle() {
+				return
+			},
+			toIndex() {
+				uni.clearStorageSync()
+				uni.switchTab({
+					url: "/pages/sub_tabbar/index"
+				})
+			},
+			login() {
+				let that = this
+				let {
+					tel,
+					pwd
+				} = that
+				// console.log(tel,pwd)
+				if (tel == "") {
+					uni.showToast({
+						title: "请填写正确手机号",
+						duration: 800,
+						mask: true,
+						icon: "none"
+					})
+					return false
+				}
+				if (pwd == "") {
+					uni.showToast({
+						title: "请填写登录密码",
+						duration: 800,
+						mask: true,
+						icon: "none"
+					})
+					return false
+				}
+				
+				// #ifdef H5
+				let platform = 'H5'
+				let uuid = ''
+				// #endif
+				
+				// #ifdef APP-PLUS
+				let uuid = app.globalData.clientid ? app.globalData.clientid:''
+				let platform = uni.getStorageSync('platform') ? 'App-' + uni.getStorageSync('platform') : ''
+				// #endif
+				
+				// #ifdef MP-WEIXIN
+				let platform = uni.getStorageSync('platform') ? 'Wechat-' + uni.getStorageSync('platform') : ''
+				let uuid = ''
+				// #endif
+				
+				let params = {
+					username: tel,
+					password: pwd,
+					deviceid: uuid,
+					platform: platform
+				}
+				that.$u.post('/login',params).then(res => {
+					
+					uni.setStorageSync("token", res.token)
+					uni.setStorageSync("uid", res.uid)
+					uni.setStorageSync("userid", res.userid)
+					uni.setStorageSync("tenantid", res.tenantid)
+					uni.setStorageSync("tokenexpire", res.expire)
+					uni.setStorageSync("tokentime", res.now)
+					uni.setStorageSync("signed", res.signed)
+					uni.setStorageSync("paypwdset", res.paypwdset)
+					uni.setStorageSync("name", res.name)
+					uni.setStorageSync("localpwd", res.localpwd)
+					uni.setStorageSync("phone", tel)
+					uni.setStorageSync("phoneX", res.phone)
+					uni.setStorageSync("imgurl", res.imgurl)
+					uni.setStorageSync("idno", res.idno)
+					uni.setStorageSync("cardno", res.citizenCardNo)
+					uni.setStorageSync("bankcardno", res.bankCardNo)
+					let ranNum = Math.ceil(Math.random() * 25)
+					let c = String.fromCharCode(65 + ranNum)
+					// #ifndef MP-WEIXIN
+					let b = c + btoa(pwd)
+					// #endif
+					// #ifdef MP-WEIXIN
+					let b = c + pwd
+					// #endif
+					uni.setStorageSync("pwd", b)
+					if(res.needcheck){
+						uni.navigateTo({
+							url:'/pages/sub_basic/verification/index?data=' + JSON.stringify(params)
+						})
+						return false
+					}
+					uni.showToast({
+						title: "登录成功",
+						icon: "none",
+						mask: true,
+						duration: 800,
+						complete(res) {
+							setTimeout(() => {
+								uni.switchTab({
+									url: "/pages/sub_tabbar/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			},
+			fingerLogin() {
+				let that = this
+				let tel = uni.getStorageSync('phone')
+				let pwd = uni.getStorageSync('pwd')
+				// #ifdef APP-PLUS
+				let uuid = app.globalData.clientid ? app.globalData.clientid : ''
+				let platform = uni.getStorageSync('platform') ? 'App-' + uni.getStorageSync('platform') : ''
+				let a = atob(pwd.substr(1))
+				// #endif
+				
+				// #ifdef MP-WEIXIN
+				let a = pwd.substr(1)
+				let uuid = ''
+				let platform = uni.getStorageSync('platform') ? 'Wechat-' + uni.getStorageSync('platform') : ''
+				// #endif
+				
+				// #ifdef H5
+				let platform = 'H5'
+				let uuid = ''
+				let a= atob(pwd.substr(1))
+				// #endif
+				
+				let params = {
+					username: tel,
+					password: a,
+					deviceid: uuid,
+					platform: platform
+				}
+				that.$u.post('/login',params).then(res => {
+					uni.setStorageSync("token", res.token)
+					uni.setStorageSync("uid", res.uid)
+					uni.setStorageSync("userid", res.userid)
+					uni.setStorageSync("tenantid", res.tenantid)
+					uni.setStorageSync("tokenexpire", res.expire)
+					uni.setStorageSync("tokentime", res.now)
+					uni.setStorageSync("signed", res.signed)
+					uni.setStorageSync("paypwdset", res.paypwdset)
+					uni.setStorageSync("name", res.name)
+					uni.setStorageSync("localpwd", res.localpwd)
+					uni.setStorageSync("phoneX", res.phone)
+					uni.setStorageSync("imgurl", res.imgurl)
+					uni.setStorageSync("idno", res.idno)
+					uni.setStorageSync("cardno", res.citizenCardNo)
+					uni.setStorageSync("bankcardno", res.bankCardNo)
+					if(res.needcheck){
+						uni.navigateTo({
+							url:'/pages/sub_basic/verification/index?data=' + JSON.stringify(params)
+						})
+						return false
+					}
+					uni.showToast({
+						title: "指纹识别成功",
+						icon: "none",
+						mask: true,
+						complete(res) {
+							setTimeout(() => {
+								uni.switchTab({
+									url: "/pages/sub_tabbar/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			},
+			fingerIn() {
+				let that = this
+				let fingerprint = uni.getStorageSync("fingerprint")
+				if (fingerprint) {
+					uni.checkIsSoterEnrolledInDevice({
+						checkAuthMode: 'fingerPrint',
+						success(res) {
+							if (res.isEnrolled) {
+								uni.startSoterAuthentication({
+									requestAuthModes: ['fingerPrint'],
+									authContent: '指纹解锁',
+									success(res) {
+										that.fingerLogin()
+									},
+									fail(res) {
+										console.log(res)
+										if (res.errCode == "90010") {
+											uni.showToast({
+												title: "错误次数过多,功能被冻结,请尝试其他登陆方式",
+												duration: 1500,
+												icon: "none",
+												mask: true,
+											})
+										} else {
+											uni.showToast({
+												title: res.errCode,
+												duration: 1500,
+												icon: "none",
+												mask: true,
+											})
+										}
+									}
+								})
+							} else {
+								uni.showToast({
+									title: "没有录入指纹",
+									duration: 1500,
+									icon: "none",
+									mask: true,
+								})
+							}
+						},
+					})
+
+				} else {
+					uni.showToast({
+						title: "未开启指纹登录,请使用其他方式登录",
+						duration: 1500,
+						icon: "none",
+						mask: true,
+					})
+					// plus.nativeUI.toast("未开启指纹登录,请使用其他方式登录");
+				}
+			},
+			faceIn() {
+				let face = uni.getStorageSync("face")
+				if (face) {
+
+				} else {
+					uni.showToast({
+						title: "未开启面容登录,请使用其他方式登录",
+						duration: 1500,
+						icon: "none",
+						mask: true,
+					})
+					//plus.nativeUI.toast("未开启面容登录,请使用其他方式登录");
+				}
+			},
+			handsIn() {
+				let hands = uni.getStorageSync("hands")
+				if (hands) {
+					uni.setStorageSync("login", 1)
+					uni.navigateTo({
+						url: "/pages/sub_mine/lock/index"
+					})
+				} else {
+					uni.showToast({
+						title: "未开启手势登录,请使用其他方式登录",
+						duration: 1500,
+						icon: "none",
+						mask: true,
+					})
+					//plus.nativeUI.toast("未开启手势登录,请使用其他方式登录");
+				}
+			}
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.login {
+		width: 100vw;
+		font-family: "PingFang-SC-Medium";
+		background-color: #FFFFFF;
+		height: 100vh;
+		position: relative;
+
+		&-con {
+			padding: 30rpx;
+
+			&-title {
+				display: flex;
+				justify-content: space-between;
+				align-items: center;
+
+				text {
+					font-family: "PingFang-SC-Medium";
+					font-size: 32rpx;
+					color: #333333;
+				}
+			}
+
+			&-logo {
+				display: flex;
+				justify-content: center;
+				padding: 30rpx 0;
+				text-align: center;
+				align-items: center;
+			}
+
+			&-form {
+				width: 650rpx;
+				margin: 0 auto 50rpx;
+
+				&-forget {
+					color: #999999;
+					font-size: 28rpx;
+					display: flex;
+					justify-content: flex-end;
+					margin-top: 30rpx;
+				}
+			}
+
+			&-btn {
+				background-color: #2FA8E1;
+				padding: 50rpx 0;
+				color: #FFFFFF;
+				width: 600rpx;
+				font-size: 30rpx;
+				border: 1px solid #2FA8E1;
+			}
+
+			&-btnr {
+				border: 1px solid #2FA8E1;
+				padding: 50rpx 0;
+				color: #2FA8E1;
+				width: 600rpx;
+				font-size: 30rpx;
+				margin-top: 30rpx;
+			}
+
+			&-youke {
+				display: flex;
+				justify-content: center;
+				color: #999999;
+				font-size: 28rpx;
+				margin-top: 30rpx;
+			}
+
+			&-footer {
+				position: absolute;
+				bottom: 30rpx;
+				width: 500rpx;
+				left: 50%;
+				transform: translateX(-50%);
+				// width: 100vw;
+				display: flex;
+				justify-content: center;
+				flex-direction: column;
+
+				&-title {
+					display: flex;
+					justify-content: center;
+					font-size: 28rpx;
+					color: #999999;
+				}
+
+				&-icon {
+					display: flex;
+					justify-content: space-around;
+					margin-top: 30rpx;
+				}
+			}
+		}
+
+	}
+</style>
diff --git a/pages/sub_basic/network/index.vue b/pages/sub_basic/network/index.vue
new file mode 100644
index 0000000..6f247f3
--- /dev/null
+++ b/pages/sub_basic/network/index.vue
@@ -0,0 +1,36 @@
+<template>
+	<view class="network">
+		<u-no-network @retry="back"></u-no-network>
+	</view>
+</template>
+
+<script>
+	export default{
+		data(){
+			return{
+				
+			}
+		},
+		methods:{
+			back(){
+				uni.onNetworkStatusChange(function(res) {
+					if (!res.isConnected || res.networkType == '2g' || res.networkType == 'none') {
+						uni.showToast({
+							title:"网络不可用",
+							icon:"none",
+							duration:1500
+						})
+					}else{
+						uni.navigateBack({
+							delta:1
+						})
+					}
+				});
+				
+			}
+		}
+	}
+</script>
+
+<style>
+</style>
diff --git a/pages/sub_basic/register/index.vue b/pages/sub_basic/register/index.vue
new file mode 100644
index 0000000..1928b39
--- /dev/null
+++ b/pages/sub_basic/register/index.vue
@@ -0,0 +1,253 @@
+<template>
+	<view class="register" @touchmove.stop.prevent="moveHandle">
+		<!-- #ifndef MP-WEIXIN -->
+		<u-navbar title="注册" :border-bottom="false" :is-back="false"></u-navbar>
+		<!-- #endif -->
+		<view class="register-con">
+			<view class="register-con-logo">
+				<u-image src="/static/images/login/logo.png" width="300rpx" mode="widthFix"></u-image>
+			</view>
+			<view class="register-con-form">
+				<u-field v-model="tel" placeholder="请输入手机号" label-width="50" maxlength="11" type="number"clear-size="40">
+					<u-icon slot="icon" name="shouji" custom-prefix="custom-icon" color="#999999"></u-icon>
+				</u-field>
+				<u-field v-model="code" placeholder="请输入验证码" label-width="50" maxlength="6" type="number"clear-size="40">
+					<u-icon slot="icon" name="code" custom-prefix="custom-icon" color="#999999"></u-icon>
+					<u-button slot="right" @click="getCode" size="mini" :disabled="isChecked" :custom-style="btn">{{codeText}}</u-button>
+				</u-field>
+				<u-field v-model="pwd" icon="lock-fill" placeholder="请设置6-12位密码" label-width="50" icon-color="#999999" maxlength="12"
+				 :password="true" type="number"clear-size="40"></u-field>
+			</view>
+			<view class="register-con-agreement">
+				<u-checkbox v-model="checked" shape="circle" label-size="26" icon-size="16"><text style="margin-left: 20rpx;">我已同意<text class="register-con-agreement-text" @click="toUrl('/pages/sub_mine/agreement/index')">《用户协议》</text></text></u-checkbox>
+			</view>
+			<u <u-button @click="register" :custom-style="registerConBtn">立即注册</u-button>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				codeText: "获取验证码",
+				pwd: "",
+				tel: "",
+				code: "",
+				isChecked: false,
+				timer: "",
+				checked: false,
+				registerConBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				},
+				btn:{
+					color: '#2FA8E1',
+					backgroundColor: '#FFFFFF',
+					borderColor:'#2FA8E1',
+					borderWidth: '1rpx',
+					borderStyle: 'solid',
+					fontFamily: "PingFang-SC-Regular"
+				}
+			}
+		},
+		methods: {
+			moveHandle(){
+				return
+			},
+			getCode() {
+				let that = this
+				let tel = that.tel
+				if (tel == "") {
+					uni.showToast({
+						title: "请输入正确手机号",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				uni.removeStorageSync('token')
+				that.$u.post('/i/code', {
+					phone: tel
+				}).then(res => {
+					uni.showToast({
+						title: res.msg,
+						icon: "none",
+						duration: 800
+					})
+					let i = 60
+					that.isChecked = true
+					that.timer = setInterval(() => {
+						if (i != 0) {
+							i--
+							that.codeText = i + "s"
+						} else {
+							clearInterval(that.timer)
+							that.codeText = "重新获取"
+							that.isChecked = false
+						}
+					}, 1000)
+				})
+			},
+			async register() {
+				let that = this
+				let {
+					tel,
+					pwd,
+					code,
+					checked
+				} = that
+				if (tel == "") {
+					uni.showToast({
+						title: "请输入正确手机号",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (code == "") {
+					uni.showToast({
+						title: "请输入验证码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (pwd == "") {
+					uni.showToast({
+						title: "请设置您的密码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (!checked) {
+					uni.showToast({
+						title: "请先阅读并同意用户协议",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				let param = {
+					phone: tel,
+					code: code,
+				}
+				let ret = await that.$u.post("/i/checkcode", param)
+				if (ret.code === 200) {
+					let {
+						randcode,
+						uid
+					} = ret
+					let params = {
+						"pwd": pwd,
+						"repwd": pwd,
+						"id": uid,
+						"random": randcode
+						// "id":"2c9b808573b4eff001740fccd23c63fc",
+						// "random":"r5m7anoef7ku5gdsz6o4gi2rkk5enf"
+					}
+					that.$u.post("/i/register", params).then((res) => {
+						uni.setStorageSync("token", res.token)
+						uni.setStorageSync("userid", res.userid)
+						uni.setStorageSync("tenantid", res.tenantid)
+						uni.setStorageSync("tokenexpire", res.expire)
+						uni.setStorageSync("tokentime", res.now)
+						uni.setStorageSync("signed", res.signed)
+						uni.setStorageSync("paypwdset", res.paypwdset)
+						uni.showToast({
+							title: "注册成功",
+							icon: "none",
+							duration: 800,
+							complete(res) {
+								setTimeout(() => {
+									uni.reLaunch({
+										url: "/pages/sub_basic/login/index"
+									})
+								}, 1500)
+							}
+						})
+					})
+				}
+			}
+
+
+
+		},
+		onUnload() {
+			let that = this
+			clearInterval(that.timer)
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.btn {
+		border-radius: 50rpx;
+		width: 150rpx;
+		color: #2FA8E1;
+		border: 2rpx #2FA8E1 solid;
+		font-size: 25rpx;
+	}
+
+	.register {
+		width: 100vw;
+		font-family: "PingFang-SC-Medium";
+		background-color: #FFFFFF;
+		height: 100vh;
+
+		&-con {
+			padding: 30rpx;
+
+			&-agreement {
+				font-family: "PingFang-SC-Medium";
+				margin-left: 50rpx;
+				margin-top: 15rpx;
+				color: #999999;
+				&-text {
+					color: #2FA8E1;
+				}
+			}
+
+			&-title {
+				display: flex;
+				justify-content: space-between;
+				align-items: center;
+
+				text {
+					font-family: "PingFang-SC-Medium";
+					font-size: 32rpx;
+					color: #333333;
+				}
+			}
+
+			&-logo {
+				display: flex;
+				justify-content: center;
+				padding: 30rpx 0;
+				align-items: center;
+				text-align: center;
+			}
+
+			&-form {
+				width: 650rpx;
+				margin: auto;
+			}
+
+			&-btn {
+				background-color: #2FA8E1;
+				padding: 50rpx 0;
+				color: #FFFFFF;
+				width: 600rpx;
+				font-size: 30rpx;
+				margin-top: 100rpx;
+			}
+		}
+
+	}
+</style>
diff --git a/pages/sub_basic/verification/index.vue b/pages/sub_basic/verification/index.vue
new file mode 100644
index 0000000..2f60329
--- /dev/null
+++ b/pages/sub_basic/verification/index.vue
@@ -0,0 +1,126 @@
+<template>
+	<view class="verification">
+		<view class="verification-list">
+			<u-field v-model="code" label="短信验证" placeholder="请输入验证码" placeholder-style="color:#999999" clear-size="40">
+				<u-button size="mini" slot="right" type="primary" @click="getCode" shape="circle" class="btn" :disabled="disabled">{{codeText}}</u-button>
+			</u-field>
+		</view>
+		<u-button :custom-style="btn"  @click="submit">验证</u-button>
+	</view>
+</template>
+
+<script>
+	export default{
+		data(){
+			return{
+				btn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				},
+				codeText: "获取验证码",
+				code: "",
+				disabled: false,
+				obj:{}
+			}
+		},
+		methods:{
+			//获取验证码
+			getCode() {
+				let that = this
+				let param = {
+					phone: that.obj.username,
+					type: 'check'
+				}
+				uni.removeStorageSync('token')
+				that.$u.post('/i/code',param).then(res => {
+					uni.showToast({
+						title: res.msg,
+						icon: "none",
+						duration: 800
+					})
+					let i = 60
+					that.disabled = true
+					that.timer = setInterval(() => {
+						if (i != 0) {
+							i--
+							that.codeText = i + "s"
+						} else {
+							clearInterval(that.timer)
+							that.codeText = "重新获取"
+							that.disabled = false
+						}
+					}, 1000)
+				})
+			},
+			submit() {
+				let that = this
+				let code = that.code
+				if (code == "") {
+					uni.showToast({
+						title: "请输入验证码",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				let params = {
+					phone:that.obj.username,
+					code: code,
+					deviceid: that.obj.deviceid,
+					platform: that.obj.platform
+				}
+				
+				that.$u.post("/sms/login",params).then((res) => {
+					uni.setStorageSync("token", res.token)
+					uni.setStorageSync("uid", res.uid)
+					uni.setStorageSync("userid", res.userid)
+					uni.setStorageSync("tenantid", res.tenantid)
+					uni.setStorageSync("tokenexpire", res.expire)
+					uni.setStorageSync("tokentime", res.now)
+					uni.setStorageSync("signed", res.signed)
+					uni.setStorageSync("paypwdset", res.paypwdset)
+					uni.setStorageSync("name", res.name)
+					uni.setStorageSync("localpwd", res.localpwd)
+					uni.setStorageSync("phoneX", res.phone)
+					uni.setStorageSync("imgurl", res.imgurl)
+					uni.setStorageSync("idno", res.idno)
+					uni.setStorageSync("cardno", res.citizenCardNo)
+					uni.setStorageSync("bankcardno", res.bankCardNo)
+					uni.showToast({
+						title: "验证成功",
+						icon: "none",
+						complete(res) {
+							setTimeout(() => {
+								uni.reLaunch({
+									url: "/pages/sub_tabbar/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			}
+		},
+		onLoad(options) {
+			let data = JSON.parse(options.data)
+			this.obj = data
+			this.getCode()
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.verification {
+		width: 100vw;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+		&-list {
+			margin-top: 30rpx;
+			background-color: #FFFFFF;
+		}
+	}
+</style>
diff --git a/pages/sub_index/activateCard/index.vue b/pages/sub_index/activateCard/index.vue
new file mode 100644
index 0000000..8fc7bfe
--- /dev/null
+++ b/pages/sub_index/activateCard/index.vue
@@ -0,0 +1,152 @@
+<template>
+	<view class="activateCard">
+		<view class="activateCard-list">
+			<u-field v-model="name" label="姓名" placeholder="请输入真实姓名" clear-size="40"></u-field>
+			<u-field v-model="tel" label="电话" placeholder="请填写联系电话" clear-size="40"></u-field>
+			<u-field v-model="address" label="地址" placeholder="请填写地址" clear-size="40"></u-field>
+		</view>
+		<view class="activateCard-getId">
+			<text class="activateCard-getId-title">身份证上传</text>
+			<view class="activateCard-getId-photo">
+				<u-upload ref="uUpload" @on-uploaded="onUploaded" :action="action" :auto-upload="false" max-count="1" :custom-btn="true">
+					<view slot="addBtn" class="slot-btn">
+						<u-image src="/static/images/activateCard/photo.png" width="100%" height="100%" mode="aspectFit"></u-image>
+					</view>
+				</u-upload>
+				<u-upload ref="uUpload" @on-uploaded="onUploaded" :action="action" :auto-upload="false" max-count="1" :custom-btn="true">
+					<view slot="addBtn" class="slot-btn">
+						<u-image src="/static/images/activateCard/photo1.png" width="100%" height="100%" mode="aspectFit"></u-image>
+					</view>
+				</u-upload>
+			</view>
+		</view>
+		<view class="activateCard-getId">
+			<text class="activateCard-getId-title">其他证件上传</text>
+			<view class="activateCard-getId-photo">
+				<u-upload ref="uUpload" @on-uploaded="onUploaded" :action="action" :auto-upload="false" max-count="1" :custom-btn="true">
+					<view slot="addBtn" class="slot-btn">
+						<u-image src="/static/images/activateCard/photo2.png" width="100%" height="100%" mode="aspectFit"></u-image>
+					</view>
+				</u-upload>
+				<u-upload ref="uUpload" @on-uploaded="onUploaded" :action="action" :auto-upload="false" max-count="1" :custom-btn="true">
+					<view slot="addBtn" class="slot-btn">
+						<u-image src="/static/images/activateCard/photo2.png" width="100%" height="100%" mode="aspectFit"></u-image>
+					</view>
+				</u-upload>
+			</view>
+		</view>
+		<view class="activateCard-footer">
+			<text>规则说明:</text>
+			<text>若是外来居民,则需要上传居住证;</text>
+			<text>若是申请普通卡,则需要上传身份证;</text>
+			<text>若是申请学生卡,则需要上传身份证、学生证、户口本;</text>
+			<text>若是申请爱心卡,则需要上传身份证、低保证;</text>
+			<text>若是申请老年卡,则需要上传身份证、老年优待证。</text>
+		</view>
+		<u-button :custom-style="activateCardBtn" @click="submit">提交</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				name: "",
+				tel: "",
+				address: "",
+				filesArr: [],
+				action: "http://www.example.com/upload",
+				activateCardBtn: {
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+				    color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '30rpx',
+					padding: '50rpx 0'
+				}
+
+			}
+		},
+		methods: {
+			onUploaded(lists) {
+				this.filesArr = lists;
+			},
+			submit() {
+				this.$refs.uUpload.upload();
+			},
+			submit(){
+				uni.showToast({
+					title:"app开卡功能尚未开启",
+					icon:'none',
+					duration:1500
+				})
+			}
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.slot-btn {
+		width: 350rpx;
+		height: 300rpx;
+	}
+
+	.activateCard {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		&-list {
+			margin-top: 30rpx;
+			background-color: #FFFFFF;
+		}
+
+		&-getId {
+			width: 720rpx;
+			margin: 30rpx auto 0;
+			background-color: #FFFFFF;
+			border-radius: 10rpx;
+			padding: 30rpx 10rpx;
+
+			&-title {
+				font-family: "PingFang-SC-Medium";
+				font-size: 30rpx;
+			}
+
+			&-photo {
+				display: flex;
+				justify-content: space-between;
+				margin-top: 30rpx;
+			}
+		}
+
+		&-footer {
+			// margin-top: 30rpx;
+			padding: 30rpx;
+			display: flex;
+			flex-direction: column;
+			font-family: "PingFang-SC-Medium";
+			font-size: 26rpx;
+
+			text {
+				&:nth-child(1) {
+					font-size: 30rpx;
+					margin-bottom: 10rpx;
+				}
+			}
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 30rpx;
+			padding: 50rpx 0;
+		}
+	}
+</style>
diff --git a/pages/sub_index/activeDetails/index.vue b/pages/sub_index/activeDetails/index.vue
new file mode 100644
index 0000000..13fed63
--- /dev/null
+++ b/pages/sub_index/activeDetails/index.vue
@@ -0,0 +1,208 @@
+<template>
+	<view class="activeDetails">
+		<!-- #ifndef H5 -->
+		<view class="bgColor"></view>
+		<!-- #endif -->
+		<view v-if="!show">
+			<view class="activeDetails-title">
+				<text class="activeDetails-title-title">{{article.title}}</text>
+				<view class="activeDetails-title-author">
+					<text class="activeDetails-title-author-author">{{article.author}}</text>
+					<text class="activeDetails-title-author-date">{{creatime}}</text>
+					<view></view>
+					<view class="activeDetails-title-author-watch">
+						<u-icon name="eye" color="#9A9A9A" size="28"></u-icon>
+						<text>{{article.hits}}</text>
+					</view>
+				</view>
+			</view>
+			<view class="richText">
+				<u-parse :html="article.content" :lazy-load="true"></u-parse>
+			</view>
+			<u-button :custom-style="activeDetailsBtn" @click="join" v-if="isShowBtn">报名</u-button>
+		</view>
+		<u-empty text="活动不存在" mode="page" font-size="40" :show="show" margin-top="300"></u-empty>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				article: {},
+				creatime: "",
+				activeDetailsBtn: {
+					width: "650rpx",
+					backgroundColor: "#30A8E1",
+					color: " #FFFFFF",
+					padding: "50rpx 0 ",
+					position: "fixed",
+					bottom: "30rpx",
+					left: "50%",
+					transform: "translateX(-50%)",
+					isShowBtn:false
+				},
+				show: true
+			}
+		},
+		methods: {
+			join(){
+				uni.showToast({
+					title:"此活动暂时无法报名",
+					icon:"none",
+					duration:1500
+				})
+			},
+			getArticle(id) {
+				let that = this
+				that.$u.post("/i/activity/" + id).then(res => {
+					that.show = false
+					that.article = res.data
+					//修改发布时间
+					let time = new Date(res.data.createtime.substr(0, 19))
+					//console.log(time)
+					let year = time.getFullYear()
+					let month = (time.getMonth() + 1 )> 10 ? time.getMonth() + 1 : '0' + (time.getMonth() + 1 )
+					let date = time.getDay()
+					let hour = time.getHours() >10 ? time.getHours() : '0' +  time.getHours()
+					let min = time.getMinutes() >10 ? time.getMinutes() : '0' +  time.getMinutes()
+					let sec = time.getSeconds() >10 ? time.getSeconds() : '0' +  time.getSeconds()
+					if (Number(date) < 10) {
+						date = "0" + date
+					}
+					let newtime = year + '-' + month + '-' + date + ' ' + hour + ':' + min + ':' + sec
+					let now = Number(new Date().getTime())
+					let old = Number(new Date(res.data.createtime.substr(0, 19)).getTime())
+					let minus = Math.floor((now - old) / (60 * 60 * 1000))
+					//console.log(minus)
+					if (minus > 24) {
+						that.creatime = newtime
+					} else if(minus == 0){
+						that.creatime = "刚刚"
+					} else {
+						that.creatime = minus + "小时前"
+					}
+					//修改富文本图片样式
+					// const regex = new RegExp('<img', 'gi');
+					// res.data.content = res.data.content.replace(regex, `<img style=""`)
+				}).catch(res=>{
+					that.show = true
+				})
+			}
+		},
+		onLoad(option) {
+			// console.log(option.id)
+			let type = option.type
+			if(type == 'OnlineActivities'){
+				this.isShowBtn = true
+			}else{
+				this.isShowBtn = false
+			}
+			this.getArticle(option.id)
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.richText {
+		padding: 20rpx 20rpx 150rpx;
+		text-align: justify;
+	}
+	page{
+		background-color: #FFFFFF;
+	}
+	/* #ifndef H5 */
+	.bgColor {
+		position: fixed;
+		top: 0;
+		left: 0;
+		right: 0;
+		bottom: 0;
+		background: #FFFFFF;
+		z-index: -1;
+	}
+	/* #endif */
+	
+
+	.activeDetails {
+		font-family: "PingFang-SC-Medium";
+		overflow: hidden;
+		background-color: #FFFFFF;
+
+		&-btn {
+			width: 650rpx;
+			background-color: #30A8E1;
+			color: #FFFFFF;
+			padding: 50rpx 0;
+			position: fixed;
+			bottom: 30rpx;
+			left: 50%;
+			transform: translateX(-50%);
+		}
+
+		&-title {
+			display: flex;
+			flex-direction: column;
+			padding: 20rpx;
+			background-color: #FFFFFF;
+
+			&-title {
+				color: #343434;
+				font-size: 30rpx;
+			}
+
+			&-author {
+				color: #9A9A9A;
+				font-size: 25rpx;
+				display: flex;
+				justify-content: space-between;
+				margin-top: 10rpx;
+			}
+		}
+
+		&-condition {
+			background-color: #FFFFFF;
+			padding: 20rpx;
+
+			&-con {
+				&-con {
+					color: #666666;
+					font-size: 28rpx;
+				}
+
+				&-title {
+					color: #333333;
+					font-size: 28rpx;
+					margin-right: 10rpx;
+				}
+			}
+
+			&-lay {
+				display: flex;
+				color: #666666;
+
+				&-con {
+					display: flex;
+					flex-direction: column;
+				}
+			}
+		}
+
+		&-introduce {
+			background-color: #FFFFFF;
+			display: flex;
+			font-size: 28rpx;
+			flex-direction: column;
+			padding: 0 20rpx 150rpx;
+
+			&-title {
+				color: #333333;
+				margin: 30rpx 0;
+			}
+
+			&-con {
+				color: #666666;
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_index/busRecords/index.vue b/pages/sub_index/busRecords/index.vue
new file mode 100644
index 0000000..92c4444
--- /dev/null
+++ b/pages/sub_index/busRecords/index.vue
@@ -0,0 +1,67 @@
+<template>
+	<view class="busRecords">
+		<view class="busRecords-item">
+			<u-image src="/static/images/busQrcode/bus.png" width="80rpx" height="80rpx" mode="aspectFit"></u-image>
+			<view class="busRecords-item-con">
+				<text>公交</text>
+				<text>大理公交</text>
+				<text>乘车时间:2020-03-02 13:00:09</text>
+			</view>
+			<text></text>
+			<text></text>
+			<text class="busRecords-item-cost">-1.98</text>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+
+			}
+		},
+		methods: {
+
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.busRecords {
+		padding: 0 30rpx;
+		background-color: #FFFFFF;
+		margin-top: 5rpx;
+		font-family: "PingFang-SC-Medium";
+		&-item {
+			display: flex;
+			align-items: center;
+			justify-content: space-between;
+			border-bottom: 1rpx solid #CCCCCC;
+			padding: 10rpx 0 20rpx;
+			&-con {
+				display: flex;
+				flex-direction: column;
+				text{
+					&:nth-child(1){
+						color: #666666;
+						font-size: 28rpx;
+					}
+					&:nth-child(2){
+						color: #343434;
+						font-size: 30rpx;
+					}
+					&:nth-child(3){
+						color: #9A9A9A;
+						font-size: 25rpx;
+					}
+				}
+			}
+			&-cost{
+				font-size: 32rpx;
+				color: #333333;
+			}
+
+		}
+	}
+</style>
diff --git a/pages/sub_index/cardApply/index.vue b/pages/sub_index/cardApply/index.vue
new file mode 100644
index 0000000..217ab3e
--- /dev/null
+++ b/pages/sub_index/cardApply/index.vue
@@ -0,0 +1,164 @@
+<template>
+	<view class="cardApply">
+		<view class="cardApply-card">
+			<view class="cardApply-card-title">
+				<view style="display: flex;align-items: center;">
+					<u-icon name="cardid" color="#ffffff" size="36" custom-prefix="custom-icon"></u-icon>
+					<text style="margin-left: 10rpx;">市民卡号:{{cardno}}</text>
+				</view>
+				<text>普通卡</text>
+				<!-- <text></text> -->
+			</view>
+			<view class="cardApply-card-no">
+				<text class="cardApply-card-no-title">银行卡号</text>
+				<view class="cardApply-card-no-box">
+					<text>****</text>
+					<text>****</text>
+					<text>****</text>
+					<text>{{bankcardno}}</text>
+				</view>
+			</view>
+			<view class="cardApply-card-footer">
+				<text>持卡人:{{name}}</text>
+				<!-- <text>到期时间:2020.09.10</text> -->
+				<text></text>
+			</view>
+		</view>
+		<!-- <u-button :custom-style="cardApplyBtn" @click="apply">申请其他卡</u-button> -->
+		<view class="cardApply-footer">
+			<text>我的权益:</text>
+			<text>公交乘车:普通卡9折、爱心卡、学生卡原价5折;阳光卡、老年卡每年享1500次免费乘坐。</text>
+			<text>市民卡日(每月第一周的周六周日):到指定商户消费享受最低5折优惠。 </text>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				cardApplyBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '50rpx',
+					padding: '50rpx 0'
+				},
+				name:'',
+				bankcardno:'',
+				cardno:''
+			}
+		},
+		methods: {
+			apply(){
+				uni.showToast({
+					title:"暂无其他卡可申请",
+					icon:"none",
+					duration:1500
+				})
+			}
+		},
+		onLoad(){
+			let that = this
+			that.name = uni.getStorageSync('name')?uni.getStorageSync('name'):'佚名'
+			that.bankcardno = uni.getStorageSync('bankcardno')?uni.getStorageSync('bankcardno').substr(uni.getStorageSync('bankcardno').length-4):'****'
+			that.cardno = uni.getStorageSync('cardno')?uni.getStorageSync('cardno'):'暂无市民卡信息'
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	
+	.cardApply {
+		height: 100vh;
+		background-color: #FFFFFF;
+		overflow: hidden;
+		&-footer{
+			display: flex;
+			flex-direction: column;
+			margin-top: 50rpx;
+			padding: 30rpx;
+			font-family: "PingFang-SC-Medium";
+			color: #666666;
+			text{
+				&:nth-child(1){
+					color: #333333;
+					font-size: 28rpx;
+				}
+			}
+		}
+
+		&-card {
+			background-image: url();
+			background-position: center;
+			background-size: cover;
+			background-repeat: no-repeat;
+			color: #FFFFFF;
+			width: 690rpx;
+			margin: 30rpx auto;
+			border-radius: 10rpx;
+			padding: 50rpx 30rpx 30rpx;
+			font-family: "PingFang-SC-Medium";
+
+			&-title {
+				display: flex;
+				align-items: center;
+				margin-bottom: 30rpx;
+				justify-content: space-between;
+
+				text {
+					&:nth-child(1) {
+						font-size: 24rpx;
+					}
+
+					&:nth-child(2) {
+						font-size: 28rpx;
+					}
+				}
+			}
+
+			&-no {
+				margin-bottom: 30rpx;
+
+				&-title {
+					font-size: 28rpx;
+				}
+
+				&-box {
+					margin-top: 10rpx;
+					display: flex;
+					justify-content: space-between;
+					align-items: center;
+					font-size: 46rpx;
+				}
+			}
+
+			&-footer {
+				display: flex;
+				justify-content: space-between;
+				align-items: center;
+				font-size: 28rpx;
+			}
+
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 50rpx;
+			padding: 50rpx 0;
+		}
+	}
+	/* #ifdef APP-PLUS */
+	.cardApply{
+		&-card{
+			background-image: url(/static/images/cardApply/banner.png);
+		}
+	}
+	/* #endif */
+</style>
diff --git a/pages/sub_index/chat/index.vue b/pages/sub_index/chat/index.vue
new file mode 100644
index 0000000..20c9f37
--- /dev/null
+++ b/pages/sub_index/chat/index.vue
@@ -0,0 +1,52 @@
+<template>
+	<view class="chat">
+		<view class="chat-list">
+			<u-cell-group>
+				<u-cell-item title="人工咨询" @click="toPath()">
+					<u-icon slot="icon" size="32" name="kefu" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+				<u-cell-item title="智能机器人" @click="toPath()">
+					<u-icon slot="icon" size="32" name="robot" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+				<u-cell-item title="资讯库" @click="toPath('')">
+					<u-icon slot="icon" size="32" name="zx" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+				<u-cell-item title="网点查询" @click="toPath('/pages/sub_index/offlineHelp/index')">
+					<u-icon slot="icon" size="32" name="offlineHelp" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+				<u-cell-item title="常见问题" @click="toPath('/pages/sub_index/question/index')">
+					<u-icon slot="icon" size="32" name="question" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+			</u-cell-group>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+
+			}
+		},
+		methods: {
+			
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	/deep/.u-cell_title{
+		margin-left: 30rpx;
+	}
+	.chat {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+		&-list {
+			margin-top: 30rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_index/chatDetails/index.vue b/pages/sub_index/chatDetails/index.vue
new file mode 100644
index 0000000..8d0befc
--- /dev/null
+++ b/pages/sub_index/chatDetails/index.vue
@@ -0,0 +1,297 @@
+<template>
+	<view class="chatDetails" @touchmove.stop.prevent="moveHandle">
+		<view class="chatDetails-header">
+			<view class="chatDetails-header-title">
+				今天有去苍山的吗?一起拼个车呗!仅限女生哦,小姐姐快来联系我吧~
+			</view>
+			<view class="chatDetails-header-avatar">
+				<u-avatar :src="avatar" size="110"></u-avatar>
+				<view class="chatDetails-header-avatar-desc">
+					<text class="chatDetails-header-avatar-desc-name">李萌萌</text>
+					<text class="chatDetails-header-avatar-desc-date">3小时前</text>
+				</view>
+			</view>
+			<view class="chatDetails-header-con">
+				今天下午1点到4点,有没有小伙伴想去苍山的啊?有的话我们就一起呗,路上有个陪伴,还能多认识一些小伙伴对不对呀,限女生哦~有一起拼车的小姐姐们记得找我哦!
+			</view>
+		</view>
+		<view class="chatDetails-line"></view>
+		<scroll-view :scroll-y="true" :style="{height:height+'px'}" class="scrollView">
+			<view class="chatDetails-items">
+				<view class="chatDetails-items-desc">
+					<view class="chatDetails-items-desc-left">
+						<u-avatar :src="avatar" size="112"></u-avatar>
+					</view>
+					<view class="chatDetails-items-desc-right">
+						<view class="chatDetails-items-desc-right-author">
+							<text class="chatDetails-items-desc-right-author-name">刘壮壮</text>
+							<view class="chatDetails-items-desc-right-author-sup">
+								<text>166</text>
+								<u-icon name="thumb-up-fill" color="#8A8A8A" size="26"></u-icon>
+							</view>
+						</view>
+						<view class="chatDetails-items-desc-right-date">1小时前</view>
+						<view class="chatDetails-items-desc-right-desc">男生就没有机会了吗?嘤嘤嘤~~~</view>
+					</view>
+				</view>
+			</view>
+			<view class="chatDetails-items">
+				<view class="chatDetails-items-desc">
+					<view class="chatDetails-items-desc-left">
+						<u-avatar :src="avatar" size="112"></u-avatar>
+					</view>
+					<view class="chatDetails-items-desc-right">
+						<view class="chatDetails-items-desc-right-author">
+							<text class="chatDetails-items-desc-right-author-name">刘壮壮</text>
+							<view class="chatDetails-items-desc-right-author-sup">
+								<text>166</text>
+								<u-icon name="thumb-up-fill" color="#8A8A8A" size="26"></u-icon>
+							</view>
+						</view>
+						<view class="chatDetails-items-desc-right-date">1小时前</view>
+						<view class="chatDetails-items-desc-right-desc">男生就没有机会了吗?嘤嘤嘤~~~</view>
+					</view>
+				</view>
+			</view>
+			<view class="chatDetails-items">
+				<view class="chatDetails-items-desc">
+					<view class="chatDetails-items-desc-left">
+						<u-avatar :src="avatar" size="112"></u-avatar>
+					</view>
+					<view class="chatDetails-items-desc-right">
+						<view class="chatDetails-items-desc-right-author">
+							<text class="chatDetails-items-desc-right-author-name">刘壮壮</text>
+							<view class="chatDetails-items-desc-right-author-sup">
+								<text>166</text>
+								<u-icon name="thumb-up-fill" color="#8A8A8A" size="26"></u-icon>
+							</view>
+						</view>
+						<view class="chatDetails-items-desc-right-date">1小时前</view>
+						<view class="chatDetails-items-desc-right-desc">男生就没有机会了吗?嘤嘤嘤~~~</view>
+					</view>
+				</view>
+			</view>
+			<view class="chatDetails-items">
+				<view class="chatDetails-items-desc">
+					<view class="chatDetails-items-desc-left">
+						<u-avatar :src="avatar" size="112"></u-avatar>
+					</view>
+					<view class="chatDetails-items-desc-right">
+						<view class="chatDetails-items-desc-right-author">
+							<text class="chatDetails-items-desc-right-author-name">刘壮壮</text>
+							<view class="chatDetails-items-desc-right-author-sup">
+								<text>166</text>
+								<u-icon name="thumb-up-fill" color="#8A8A8A" size="26"></u-icon>
+							</view>
+						</view>
+						<view class="chatDetails-items-desc-right-date">1小时前</view>
+						<view class="chatDetails-items-desc-right-desc">男生就没有机会了吗?嘤嘤嘤~~~</view>
+					</view>
+				</view>
+			</view>
+		</scroll-view>
+		<view class="chatDetails-bottom">
+			<u-icon name="chat" color="#999999" size="44"></u-icon>
+			<text class="chatDetails-bottom-num">12</text>
+			<view class="chatDetails-bottom-ipt">
+				<u-search placeholder="说点什么吧" v-model="val" :show-action="false"></u-search>
+			</view>
+			<u-icon name="thumb-up" color="#999999" size="44"></u-icon>
+			<u-button size="mini" :custom-style="chatDetailsBottomBtn">发送</u-button>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				avatar: "",
+				val: "",
+				height: "",
+				chatDetailsBottomBtn:{
+					color: '#ffffff',
+					backgroundColor: '#30A8E1',
+					borderRadius: '50rpx',
+					padding: '30rpx 40rpx',
+					marginLeft: '10rpx',
+				}
+			}
+		},
+		methods: {
+			moveHandle() {
+				return
+			},
+			getSrcollViewHeight(){
+				let winHeight
+				let that =this
+				uni.getSystemInfo({
+					success: function(res) {
+						winHeight = res.windowHeight
+					}
+				});
+				const query = uni.createSelectorQuery().in(that);
+				let top,height
+				query.select('.scrollView').boundingClientRect(data => {
+					console.log(data)
+					top = Number(data.top)
+				}).exec();
+				query.select('.chatDetails-bottom').boundingClientRect(data => {
+					height = Number(data.height)
+					that.height = winHeight - top - height
+				}).exec();
+			}
+		},
+		onLoad() {
+
+		},
+		onReady() {
+			this.getSrcollViewHeight()
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	scroll-view ::-webkit-scrollbar {
+		width: 0;
+		height: 0;
+		display: none;
+		background-color: transparent;
+	}
+
+	.scrollView {
+		// height: calc(100vh - 560rpx);
+		// padding-bottom: 150rpx;
+	}
+
+	.chatDetails {
+		width: 100vw;
+		background-color: #FFFFFF;
+		font-family: "PingFang-SC-Medium";
+
+		&-header {
+			padding: 30rpx;
+
+			&-title {
+				color: #343434;
+				font-size: 31rpx;
+			}
+
+			&-avatar {
+				display: flex;
+				margin: 30rpx 0 20rpx;
+
+				&-desc {
+					display: flex;
+					flex-direction: column;
+					justify-content: space-around;
+					margin-left: 20rpx;
+
+					&-name {
+						color: #343434;
+						font-size: 28rpx;
+					}
+
+					&-date {
+						color: #9A9A9A;
+						font-size: 24rpx;
+					}
+				}
+			}
+
+			&-con {
+				color: #666666;
+				font-size: 28rpx;
+			}
+		}
+
+		&-line {
+			width: 100%;
+			height: 2rpx;
+			background-color: rgba(204, 204, 204, 1);
+			margin: 10rpx 0 0;
+		}
+
+		&-items {
+			padding: 30rpx;
+
+			&-desc {
+				display: flex;
+
+				&-right {
+					width: 80%;
+					margin-left: 20rpx;
+					margin-top: 15rpx;
+
+					&-author {
+						display: flex;
+						align-items: center;
+						justify-content: space-between;
+
+						&-name {
+							color: #343434;
+							font-size: 28rpx;
+						}
+
+						&-sup {
+							color: #9A9A9A;
+							font-size: 24rpx;
+							display: flex;
+							align-items: center;
+
+							text {
+								margin-right: 10rpx;
+							}
+						}
+					}
+
+					&-date {
+						color: #9A9A9A;
+						font-size: 24rpx;
+						margin: 10rpx 0;
+					}
+
+					&-desc {
+						color: #666666;
+						font-size: 28rpx;
+						display: inline-block;
+						text-align: justify;
+					}
+				}
+
+			}
+		}
+
+		&-bottom {
+			position: fixed;
+			bottom: 0;
+			width: 100vw;
+			height: 120rpx;
+			padding: 30rpx;
+			display: flex;
+			background-color: #FFFFFF;
+			align-items: center;
+			border-top: 2rpx rgba(100, 100, 100, 0.09) solid;
+
+			&-num {
+				color: #9A9A9A;
+				font-size: 24rpx;
+				font-family: "PingFang-SC-Regular";
+				margin: 0 20rpx 0 5rpx;
+			}
+
+			&-ipt {
+				width: 65%;
+				margin-right: 20rpx;
+			}
+
+			&-btn {
+				color: #ffffff;
+				background-color: #30A8E1;
+				border-radius: 50rpx;
+				padding: 30rpx 40rpx;
+				margin-left: 10rpx;
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_index/chatIssue/index.vue b/pages/sub_index/chatIssue/index.vue
new file mode 100644
index 0000000..fa3f256
--- /dev/null
+++ b/pages/sub_index/chatIssue/index.vue
@@ -0,0 +1,241 @@
+<template>
+	<view class="chatIssue">
+		<!-- #ifdef APP-PLUS -->
+		<view class="bgColor"></view>
+		<!-- #endif -->
+		<u-sticky>
+			<view class="chatIssue-tabs">
+				<u-tabs :list="list" :current="current" @change="change" bar-width="250" item-width="250"></u-tabs>
+			</view>
+			<view class="chatIssue-con">
+				<view class="chatIssue-con-search">
+					<u-search placeholder="搜索关键词" v-model="val" action-text="+  发布" :show-action="false" @search="search"></u-search>
+				</view>
+				<view class="chatIssue-con-add" @click="toPath('/pages/sub_index/issueQuestion/index')">
+					<u-icon name="plus" color="#333333" size="32"></u-icon>
+					<text class="chatIssue-con-add-text">发布</text>
+				</view>
+			</view>
+		</u-sticky>
+		<view v-if="current===1">
+			<view class="chatIssue-item">
+				<view class="chatIssue-item-avatar">
+					<u-avatar :src="avatar" size="110"></u-avatar>
+				</view>
+				<view class="chatIssue-item-con">
+					<view class="chatIssue-item-con-title" @click="toPath('/pages/sub_index/chatDetails/index')">哇,好大的雪啊,你们那里雪大吗?</view>
+					<view class="chatIssue-item-con-author">
+						<view class="chatIssue-item-con-author-left">
+							<text>张嚣</text>
+							<text>06:36</text>
+						</view>
+						<view class="chatIssue-item-con-author-km">
+							<u-icon name="map" color="#999999" size="24"></u-icon>
+							<text>3.6km</text>
+						</view>
+					</view>
+					<view class="chatIssue-item-con-desc">
+						早上一觉醒来,迷迷糊糊拉开窗帘,便见到如此景象忍不住想分享,太美了!!!
+					</view>
+					<view class="chatIssue-item-con-img">
+						<scroll-view :scroll-x="true" class="scrollView">
+							<view class="chatIssue-item-con-img-items">
+								<u-image width="100%" height="100%" mode="aspectFit" src="/static/images/index/bannar.png"></u-image>
+							</view>
+							<view class="chatIssue-item-con-img-items">
+								<u-image width="100%" height="100%" mode="aspectFit" src="/static/images/index/bannar.png"></u-image>
+							</view>
+							<view class="chatIssue-item-con-img-items">
+								<u-image width="100%" height="100%" mode="aspectFit" src="/static/images/index/bannar.png"></u-image>
+							</view>
+							<view class="chatIssue-item-con-img-items">
+								<u-image width="100%" height="100%" mode="aspectFit" src="/static/images/index/bannar.png"></u-image>
+							</view>
+						</scroll-view>
+					</view>
+					<view class="chatIssue-item-con-footer">
+						<view class="chatIssue-item-con-footer-watcher">
+							<u-icon name="eye" color="#999999" size="24"></u-icon>
+							<text>3456</text>
+						</view>
+						<view class="chatIssue-item-con-footer-chat">
+							<u-icon name="chat" color="#999999" size="24"></u-icon>
+							<text>34</text>
+						</view>
+					</view>
+				</view>
+			</view>
+		</view>
+		<view v-if="current === 0">
+			<u-empty text="暂无动态" mode="list" margin-top="300"></u-empty>
+		</view>
+		<view v-if="current === 2">
+			<u-empty text="暂无动态" mode="list" margin-top="300"></u-empty>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				list: [{
+						name: "人气热帖"
+					},
+					{
+						name: "附近邻居"
+					},
+					{
+						name: "最新发布"
+					}
+				],
+				current: 1,
+				val: "",
+				avatar: ""
+			}
+		},
+		methods: {
+			change(index) {
+				this.current = index
+			},
+			search(e) {
+				uni.showToast({
+					icon: "none",
+					title: "搜索服务功能暂未开通",
+					duration: 1500
+				})
+			},
+
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.scrollView {
+		white-space: nowrap;
+		height: 180rpx;
+		width: 100%;
+	}
+
+	/* #ifdef APP-PLUS */
+	.bgColor {
+		position: fixed;
+		top: 0;
+		left: 0;
+		right: 0;
+		bottom: 0;
+		background: #FFFFFF;
+		z-index: -1;
+	}
+
+	/* #endif */
+	page {
+		background-color: #FFFFFF;
+	}
+
+	.chatIssue {
+		font-family: "PingFang-SC-Medium";
+		background-color: #FFFFFF;
+
+		&-tabs {
+			box-shadow: 0 0 2rpx 6rpx rgba(222, 224, 228, 0.4);
+		}
+
+		&-con {
+			display: flex;
+			justify-content: space-between;
+			padding: 20rpx 30rpx 30rpx;
+			align-items: center;
+			background-color: #FFFFFF;
+
+			&-search {
+				width: 80%;
+			}
+
+			&-add {
+				width: 15%;
+				fontSize: '30rpx';
+				font-family: 'PingFang-SC-Medium';
+				color: '#333333';
+				display: flex;
+				align-items: center;
+
+				&-text {
+					margin-left: 10rpx;
+				}
+			}
+		}
+
+		&-item {
+			padding: 30rpx;
+			display: flex;
+			justify-content: space-between;
+
+			&-con {
+				width: 80%;
+				margin-left: 30rpx;
+				margin-top: 15rpx;
+
+				&-title {
+					color: #333333;
+					font-size: 30rpx;
+				}
+
+				&-author {
+					padding: 10rpx 0 30rpx;
+					display: flex;
+					justify-content: space-between;
+					align-items: center;
+					color: #999999;
+					font-size: 25rpx;
+
+					&-left {
+						text {
+							margin-right: 20rpx;
+						}
+					}
+				}
+
+				&-desc {
+					color: #666666;
+					font-size: 28rpx;
+				}
+
+				&-footer {
+					display: flex;
+					align-items: center;
+					font-size: 24rpx;
+					color: #999999;
+
+					&-watcher {
+						margin-right: 50rpx;
+
+						text {
+							margin-left: 10rpx;
+						}
+					}
+
+					&-chat {
+						text {
+							margin-left: 10rpx;
+						}
+					}
+				}
+
+				&-img {
+					width: 100%;
+					margin: 10rpx 0;
+
+					&-items {
+						margin-right: 30rpx;
+						border-radius: 20rpx;
+						display: inline-block;
+						width: 170rpx;
+						height: 170rpx;
+						background-color: #999999;
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_index/getCityCard/index.vue b/pages/sub_index/getCityCard/index.vue
new file mode 100644
index 0000000..ed67fab
--- /dev/null
+++ b/pages/sub_index/getCityCard/index.vue
@@ -0,0 +1,49 @@
+<template>
+	<view class="getCityCard">
+		<view class="getCityCard-list">
+			<u-cell-group>
+				<u-cell-item title="挂失" @click="toPath('/pages/sub_mine/reportheLoss/index')">
+					<u-icon slot="icon" size="32" name="gs" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+				<u-cell-item title="开卡" @click="toPath('')">
+					<u-icon slot="icon" size="32" name="file-text"></u-icon>
+				</u-cell-item>
+				<u-cell-item title="年检" @click="toPath()">
+					<u-icon slot="icon" size="32" name="jc" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+				<u-cell-item title="卡应用" @click="toPath('/pages/sub_index/cardApply/index')">
+					<u-icon slot="icon" size="32" name="card" custom-prefix="custom-icon"></u-icon>
+				</u-cell-item>
+			</u-cell-group>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+
+			}
+		},
+		methods: {
+			
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	/deep/.u-cell_title{
+		margin-left: 30rpx;
+	}
+	.getCityCard {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+		&-list {
+			margin-top: 30rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_index/introduce/index.vue b/pages/sub_index/introduce/index.vue
new file mode 100644
index 0000000..657bb24
--- /dev/null
+++ b/pages/sub_index/introduce/index.vue
@@ -0,0 +1,112 @@
+<template>
+	<view class="introduce">
+		<!-- #ifndef MP-WEIXIN -->
+		<u-navbar title="市民卡简介" :border-bottom="false" :background="background" title-color="#ffffff" back-icon-color="#Ffffff"></u-navbar>
+		<!-- #endif -->
+		<view class="introduce-con">
+			<view class="introduce-con-con">
+				<text class="introduce-con-con-title">大理市民卡</text>
+				<text class="introduce-con-con-desc">生活缴费/交通出行/自在随心</text>
+			</view>
+			<view class="introduce-con-intr">
+				<text class="introduce-con-intr-title">大理市民卡简介</text>
+				<text class="introduce-con-intr-con">大理市民卡是由大理市人民政府发放,用于市民办理个人相关社会事务、享受公共服务的多功能智能卡,是政府为市民提供公益性服务、公共事务管理及服务的信息化载体。</text>
+				<text class="introduce-con-intr-con1">市民卡应用范围<br/>包括政府(公共事业)应用、商业应用和金融应用。政府服务:教育、民政、卫生;公共事业服务:公交、道路停车、水电燃气缴费、旅游、图书馆借阅;金融服务:存款、取款、汇款、还款、刷卡支付、网上支付等商业服务:超市商场购物、餐饮酒店消费、电影购票,小额支付等。</text>
+			</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				background: {
+					'background': 'no'
+				},
+			}
+		},
+		methods: {
+			back() {
+				uni.navigateBack({
+					delta: 1
+				});
+			}
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.introduce {
+		background-image: url();
+		// background-image: url(../../static/images/introduce/bannar.png);
+		background-position: center;
+		background-size: cover;
+		background-repeat: no-repeat;
+		width: 100vw;
+		min-height: 100vh;
+		// overflow: hidden;
+		&-con {
+			padding: 30rpx;
+
+			&-con {
+				display: flex;
+				flex-direction: column;
+				align-items: center;
+				color: #2FA8E1;
+				// margin-top: 15rpx;
+
+				&-title {
+					font-size: 120rpx;
+					font-family: "PingFang-SC-Heavy";
+					font-weight: bold;
+					font-style: oblique;
+				}
+
+				&-desc {
+					font-size: 26rpx;
+				}
+			}
+
+			&-intr {
+				margin-top: 23vh;
+				display: flex;
+				flex-direction: column;
+				align-items: center;
+				background-image: url(/static/images/introduce/bannar1.png);
+				background-position: top;
+				border-radius: 30rpx;
+				background-size: cover;
+				background-repeat: no-repeat;
+				padding: 0 50rpx 100rpx;
+				font-family: "PingFang-SC-Medium";
+
+				&-title {
+					color: #ffffff;
+					line-height: 80rpx;
+					font-size: 30rpx;
+				}
+
+				&-con,&-con1 {
+					color: #666666;
+					font-size: 26rpx;
+					line-height: 50rpx;
+					margin-top: 30rpx;
+					text-indent: 50rpx;
+					text-align: justify;
+				}
+				&-con1{
+					text-indent: 0rpx;
+				}
+			}
+		}
+
+	}
+
+	/* #ifdef MP-WEIXIN */
+	page {
+		background-image: url();
+	}
+
+	/* #endif */
+</style>
diff --git a/pages/sub_index/issueQuestion/index.vue b/pages/sub_index/issueQuestion/index.vue
new file mode 100644
index 0000000..f022d3f
--- /dev/null
+++ b/pages/sub_index/issueQuestion/index.vue
@@ -0,0 +1,74 @@
+<template>
+	<view class="issueQuestion">
+		<u-navbar title="">
+			<view class="slot-wrap">
+				<u-button size="mini" :custom-style="issueQuestionBtn" @click="submit">发布</u-button>
+			</view>
+		</u-navbar>
+		<view class="issueQuestion-con">
+			<u-input v-model="value" type="textarea" :border="false" height="300" :auto-height="true" placeholder="分享新鲜事" />
+			<u-upload :action="action" ref="uUpload" :auto-upload="false" :max-size="5 * 1024 * 1024" max-count="6"></u-upload>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				value: "",
+				action: "",
+				issueQuestionBtn:{
+					backgroundColor: '#2FA8E1',
+					fontFamily: "PingFang-SC-Medium",
+					color: '#FFFFFF',
+					borderRadius: '50rpx',
+					padding: '20rpx 30rpx',
+					fontSize: '30rpx'
+				}
+			}
+		},
+		methods: {
+			submit() {
+				let files = [];
+				// 通过filter,筛选出上传进度为100的文件(因为某些上传失败的文件,进度值不为100,这个是可选的操作)
+				// files = this.$refs.uUpload.lists.filter(val => {
+				// 	return val.progress == 100;
+				// })
+				// 如果您不需要进行太多的处理,直接如下即可
+				files = this.$refs.uUpload.lists;
+				console.log(files)
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.slot-wrap {
+		display: flex;
+		flex: 1;
+		align-items: flex-end;
+		position: relative;
+		left: 37%;
+		// padding: 0 30rpx;
+	}
+
+	.issueQuestion {
+		width: 100vw;
+		height: 100vh;
+		background-color: #FFFFFF;
+
+		&-btn {
+			background-color: #2FA8E1;
+			font-family: "PingFang-SC-Medium";
+			color: #FFFFFF;
+			border-radius: 50rpx;
+			padding: 20rpx 30rpx;
+			font-size: 30rpx;
+		}
+
+		&-con {
+			padding: 10rpx 30rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_index/offlineHelp/index.nvue b/pages/sub_index/offlineHelp/index.nvue
new file mode 100644
index 0000000..89e3fe0
--- /dev/null
+++ b/pages/sub_index/offlineHelp/index.nvue
@@ -0,0 +1,428 @@
+<template>
+	<div class="offlineHelp">
+		<map id="map" class="myMap" :longitude="longitude" :latitude="latitude" :markers="markList" :circles="circles"
+		 @markertap="markertap" @labeltap="labeltap" :style="{width:windowWidth +'px',height:windowHeight+'px'}"
+		 @tap="clickMap"
+		 v-if="showMap"></map>
+		<div :class="className" ref="stations">
+			<div class="stations-title"><text class="stations-title-text">附件网点</text></div>
+			<scroll-view scroll-y="true" class="srcollView">
+				<div class="stations-items" v-for="(v,i) in stationList" :key="i" v-if="stationList.length != 0">
+					<div class="stations-items-left">
+						<text class="stations-items-left-title">{{v.name}}</text>
+						<text class="stations-items-left-desc">距离我{{v.distance}}m</text>
+					</div>
+					<div class="stations-items-btn">
+						<text class="stations-items-btn-text" @click="toDetails(i+1)">查看详情</text>
+					</div>
+				</div>
+				<div class="stations-noitems" v-if="stationList.length == 0">
+					<text class="stations-noitems-text">附近暂无网点</text>
+				</div>
+			</scroll-view>
+		</div>
+		<div class="detail" ref="details" v-if="stationList.length != 0">
+			<div class="detail-title">
+				<text class="detail-title-text">{{stationList[id].name}}</text>
+				<uni-rate :readonly="true" :value="value" size="18" activeColor="#30A8E1" margin="5" />
+				<text class="detail-title-rate">{{value}}.0分</text>
+			</div>
+			<div class="detail-subtitle">
+				<text class="detail-subtitle-text">地址:{{stationList[id].address}}</text>
+			</div>
+			<div class="detail-list">
+				<text class="detail-list-text">营业时间:{{stationList[id].starttime|changeVal}}-{{stationList[id].endtime|changeVal}}</text>
+				<text class="detail-list-text">服务范围:{{stationList[id].businescope}}等</text>
+				<text class="detail-list-text">服务热线:{{stationList[id].tel}}</text>
+			</div>
+		</div>
+	</div>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				longitude: 121.5383637152778,
+				latitude: 31.27619086371528,
+				value: 5,
+				circles: [{
+					longitude: 0,
+					latitude: 0,
+					fillColor: 'rgba(219, 244, 255, .6)',
+					radius: 1500,
+					color: 'rgba(219, 244, 255, .6)'
+				}],
+				markList: [{
+					id: 0,
+					longitude: 0,
+					latitude: 0,
+					title: '我所在位置',
+					iconPath: '/static/images/map/my.png',
+					width: 20,
+					height: 20,
+					index: 0
+				}],
+				windowWidth: "",
+				windowHeight: "",
+				stationList: [],
+				// polyline: [{
+				// 	points: [{
+				// 		latitude: 31.27619086371528,
+				// 		longitude: 121.5383637152778
+				// 	}],
+				// 	color: "#30A8E1",
+				// }],
+				className: 'stations',
+				showMap: true,
+				id: 0
+			}
+		},
+		methods: {
+			getPhoneMsg() {
+				let that = this
+				uni.getSystemInfo({
+					success: function(res) {
+						that.windowHeight = res.windowHeight
+						that.windowWidth = res.windowWidth
+					}
+				});
+			},
+			getLocation() {
+				let that = this
+				uni.getLocation({
+					type: "gcj02",
+					success(res) {
+						console.log(res)
+						that.longitude = res.longitude
+						that.latitude = res.latitude
+						that.circles[0].longitude = res.longitude
+						that.circles[0].latitude = res.latitude
+						that.markList[0].longitude = res.longitude
+						that.markList[0].latitude = res.latitude
+						that.getNearbyStations(res.longitude, res.latitude)
+					},
+					fail(res) {
+						uni.showToast({
+							icon: "none",
+							title: "获取位置信息失败",
+							duration: 1500
+						})
+					}
+				})
+			},
+			markertap(e) {
+				let that = this
+				if (e.detail.markerId != 0) {
+					that.id = e.detail.markerId - 1
+					that.nearbyAnimateOut()
+					that.detailAnimateIn()
+				} else {
+					that.nearbyAnimateIn()
+					that.detailAnimateOut()
+				}
+			},
+			toDetails(e) {
+				let that = this
+				that.id = e - 1
+				that.nearbyAnimateOut()
+				that.detailAnimateIn()
+			},
+			onregionchange(e) {
+				console.log(e)
+			},
+			getNearbyStations(longitude, latitude) {
+				let that = this
+				that.showMap = false
+				let params = {
+					location: longitude + ',' + latitude,
+					distance: 3000
+				}
+				uni.request({
+					url: "https://yy.dlsmk.cn/portal/mobileapi/i/outlets/nearby",
+					data: params,
+					method: "GET",
+					success(res) {
+						console.log(res)
+						let list = res.data.data
+						console.log(list.length)
+						if (list.length != 0) {
+							that.stationList = list
+							list.map((value, index, arr) => {
+								that.markList.push({
+									longitude: value.location.substr(0, value.location.indexOf(",")),
+									latitude: value.location.substr(value.location.indexOf(",") + 1),
+									iconPath: '/static/images/map/mark.png',
+									width: 20,
+									height: 35,
+									title: value.name,
+									id: index + 1,
+								})
+							})
+						}
+						that.showMap = true
+						that.nearbyAnimateIn()
+					},
+					fail(rej) {
+						that.showMap = true
+						uni.showModal({
+							title: "错误",
+							content: rej.code + ":" + rej.message,
+							showCancel: false,
+						})
+					}
+				})
+			},
+			//点击地图更换位置
+			clickMap(e) {
+				let that = this
+				that.nearbyAnimateIn()
+				that.detailAnimateOut()
+				//console.log(e.detail)
+			},
+
+			//动画效果
+			nearbyAnimateIn() {
+				// #ifdef APP-NVUE
+				const animation = weex.requireModule('animation')
+				animation.transition(this.$refs['stations'], {
+					styles: {
+						transform: 'translateY(-700px)',
+						transformOrigin: 'center center',
+						opacity: 1,
+						backgroundColor: "#ffffff"
+					},
+					duration: 500, //ms  
+					needLayout: true, //ms  
+					timingFunction: 'linear',
+					delay: 0 //ms  
+				}, () => {})
+				// #endif
+
+				// #ifdef MP-WEIXIN
+				this.$scope.animate('.stations', [{
+					translateY: '-700px',
+					opacity: 1,
+					backgroundColor: "#ffffff",
+					transformOrigin: 'center center'
+				}], 500, function() {})
+				// #endif
+			},
+			nearbyAnimateOut() {
+				// #ifdef APP-NVUE
+				const animation = weex.requireModule('animation')
+				animation.transition(this.$refs['stations'], {
+					styles: {
+						transform: 'translateY(700px)',
+						transformOrigin: 'center center',
+						opacity: 0,
+					},
+					duration: 500, //ms  
+					needLayout: true, //ms  
+					timingFunction: 'linear',
+					delay: 0 //ms  
+				}, () => {})
+				// #endif
+
+				// #ifdef MP-WEIXIN
+				this.$scope.animate('.stations', [{
+					translateY: '700px',
+					opacity: 0,
+					transformOrigin: 'center center'
+				}], 500, function() {})
+				// #endif
+
+			},
+			detailAnimateIn() {
+				// #ifdef APP-NVUE
+				const animation = weex.requireModule('animation')
+				animation.transition(this.$refs['details'], {
+					styles: {
+						transform: 'translateY(-850px)',
+						transformOrigin: 'center center',
+						backgroundColor: "#ffffff",
+						opacity: 1
+					},
+					duration: 500, //ms  
+					needLayout: true, //ms  
+					timingFunction: 'linear',
+					delay: 0 //ms  
+				}, () => {})
+				// #endif
+
+				// #ifdef MP-WEIXIN
+				this.$scope.animate('.detail', [{
+					translateY: '-850px',
+					opacity: 1,
+					backgroundColor: "#ffffff",
+					transformOrigin: 'center center'
+				}], 500, function() {})
+				// #endif
+
+			},
+			detailAnimateOut() {
+				// #ifdef APP-NVUE
+				const animation = weex.requireModule('animation')
+				animation.transition(this.$refs['details'], {
+					styles: {
+						transform: 'translateY(850px)',
+						transformOrigin: 'center center',
+						opacity: 0
+					},
+					duration: 500, //ms  
+					needLayout: true, //ms  
+					timingFunction: 'linear',
+					delay: 0 //ms  
+				}, () => {})
+				// #endif
+
+				// #ifdef MP-WEIXIN
+				this.$scope.animate('.detail', [{
+					translateY: '850px',
+					opacity: 0,
+					transformOrigin: 'center center'
+				}], 500, function() {})
+				// #endif
+
+			},
+
+		},
+		created() {
+			this.getLocation()
+			this.getPhoneMsg()
+		},
+		filters: {
+			changeVal(data) {
+				data = data.substr(0, 2) + ":" + data.substr(2, 2)
+				return data
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.offlineHelp {
+		position: relative;
+		justify-content: center;
+	}
+
+	.srcollView {
+		height: 450rpx;
+	}
+
+	.detail {
+		position: absolute;
+		bottom: -800px;
+		left: 50rpx;
+		background-color: #FFFFFF;
+		width: 650rpx;
+		padding: 30rpx;
+		border-radius: 10rpx;
+		overflow: hidden;
+		font-family: "PingFang-SC-Medium";
+		opacity: 0;
+
+		&-title {
+			flex-direction: row;
+			align-items: center;
+
+			&-text {
+				color: #333333;
+				font-size: 32rpx;
+				margin-right: 10rpx;
+			}
+
+			&-rate {
+				color: #30A8E1;
+				font-size: 28rpx;
+				font-family: "PingFang-SC-Medium";
+				margin-left: 10rpx;
+			}
+		}
+
+		&-subtitle {
+			margin: 13rpx 0;
+
+			&-text {
+				color: #9A9A9A;
+				font-size: 25rpx;
+			}
+		}
+
+		&-list {
+			&-text {
+				color: #666666;
+				font-size: 28rpx;
+				line-height: 50rpx;
+			}
+		}
+	}
+
+	.stations {
+		position: absolute;
+		bottom: -700px;
+		left: 50rpx;
+		width: 650rpx;
+		padding: 30rpx;
+		border-top-left-radius: 20rpx;
+		border-top-right-radius: 20rpx;
+		overflow: hidden;
+		font-family: "PingFang-SC-Medium";
+		opacity: 0;
+
+		&-title {
+			&-text {
+				color: #333333;
+				font-size: 32rpx;
+			}
+		}
+
+		&-noitems {
+			justify-content: center;
+			align-items: center;
+			margin-top: 30rpx;
+
+			&-text {
+				color: #333333;
+				font-size: 30rpx;
+			}
+		}
+
+		&-items {
+			// display: flex;
+			flex-direction: row;
+			justify-content: space-between;
+			padding: 20rpx 0;
+			align-items: center;
+			border-bottom-color: #CCCCCC;
+			border-bottom-width: 1px;
+
+			&-left {
+				// display: flex;
+				flex-direction: column;
+
+				&-title {
+					color: #666666;
+					font-size: 28rpx;
+				}
+
+				&-desc {
+					color: #999999;
+					font-size: 25rpx;
+					margin-top: 10rpx;
+				}
+			}
+
+			&-btn {
+				padding: 15rpx 30rpx;
+				background-color: #2FA8E1;
+				border-radius: 50rpx;
+
+				&-text {
+					color: #FFFFFF;
+					font-size: 25rpx;
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_index/qrcode/index.vue b/pages/sub_index/qrcode/index.vue
new file mode 100644
index 0000000..d2a5ce4
--- /dev/null
+++ b/pages/sub_index/qrcode/index.vue
@@ -0,0 +1,226 @@
+<template>
+	<view class="qrcode">
+		<!-- #ifndef MP-WEIXIN -->
+		<u-navbar title="我的码" :background="background" title-color="#ffffff" :border-bottom="false" back-icon-color="#Ffffff"></u-navbar>
+		<!-- #endif -->
+		<view class="qrcode-con">
+			<view class="qrcode-con-con">
+				<view class="qrcode-con-con-title">
+					<u-icon name="money" color="#2FA8E1" size="36" custom-prefix="custom-icon"></u-icon>
+					<text>消费支付或身份认证</text>
+				</view>
+				<view class="qrcode-con-con-qrcode">
+					<text class="qrcode-con-con-qrcode-desc">扫描二维码支付或认证身份</text>
+					<canvas canvas-id="qrcode" style="width: 250px;height: 250px;" v-if="show" />
+					<u-empty text="暂无二维码" mode="list" :show="!show"></u-empty>
+					<text>二维码每15s刷新一次</text>
+					<view class="qrcode-con-con-qrcode-box" @click="isSigned">
+						<u-icon name="reflash" color="#666666" size="40" custom-prefix="custom-icon" label="刷新" label-size="36"></u-icon>
+					</view>
+				</view>
+				<view class="qrcode-con-con-footer">
+					<u-icon name="id" color="#666666" size="36" custom-prefix="custom-icon"></u-icon>
+					<view class="qrcode-con-con-footer-desc">
+						<text class="qrcode-con-con-footer-desc-card">市民卡</text>
+						<text class="qrcode-con-con-footer-desc-no">{{cardid}}</text>
+					</view>
+				</view>
+			</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	const app = getApp()
+	import uQRCode from '@/static/js/uqrcode.js'
+	export default {
+
+		data() {
+			return {
+				val: "",
+				cardid: "",
+				background: {
+					'background': 'no'
+				},
+				show: "",
+				setInter: ""
+
+			}
+		},
+		onLoad() {
+			let that = this
+			that.cardid = uni.getStorageSync('cardno') ? uni.getStorageSync('cardno') : '暂无市民卡号信息'
+			// #ifndef H5
+			that.isSigned()
+			uni.getScreenBrightness({
+				success: function(res) {
+					that.val = res.value
+				}
+			});
+			uni.setScreenBrightness({
+				value: 1,
+				success: function() {
+					// console.log('success');
+				}
+			});
+			// #endif
+		},
+		methods: {
+			isSigned() {
+				let that = this
+				let signed = uni.getStorageSync("signed")
+				if (!signed) {
+					uni.showModal({
+						title: "提示",
+						content: "您还未绑定签约,无法使用二维码消费",
+						cancelText: "再等等",
+						confirmText: "去绑定",
+						success(res) {
+							if (res.confirm) {
+								uni.navigateTo({
+									url: "/pages/sub_mine/bindBankCard/index"
+								})
+							}
+						}
+					})
+					return false
+				}
+				that.getQrcode()
+				clearInterval(that.setInter)
+				that.setInter = setInterval(() => {
+					that.getQrcode()
+				}, 15 * 1000)
+			},
+			getQrcode() {
+				let that = this
+				let param = {
+					version:app.globalData.version
+				}
+				that.$u.post("/v1/qrcode", param).then((res) => {
+					that.show = true
+					uQRCode.make({
+						canvasId: 'qrcode',
+						componentInstance: this,
+						text: res.qrcode,
+						size: 250,
+						margin: 10,
+						backgroundColor: '#ffffff',
+						foregroundColor: '#000000',
+						fileType: 'jpg',
+						correctLevel: uQRCode.errorCorrectLevel.H,
+						success: res => {
+							// console.log(res)
+						}
+					})
+				}).catch(res => {
+					that.show = false
+				})
+			},
+		},
+		onUnload() {
+			// #ifndef H5
+			let that = this
+			clearInterval(that.setInter)
+			uni.setScreenBrightness({
+				value: that.val,
+				success: function() {
+					// console.log('success');
+				}
+			});
+			// #endif
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.qrcode {
+		width: 100vw;
+		height: 100vh;
+		background-color: #2FA8E1;
+
+		&-con {
+			padding: 30rpx;
+
+			// border-radius: 20rpx;
+			&-title {
+				display: flex;
+				justify-content: space-between;
+				align-items: center;
+				color: #FFFFFF;
+
+				text {
+					font-family: "PingFang-SC-Medium";
+					font-size: 32rpx;
+				}
+			}
+
+			&-con {
+				margin-top: 100rpx;
+				font-family: "PingFang-SC-Medium";
+
+				&-title {
+					background-color: #F7F7F7;
+					font-size: 30rpx;
+					display: flex;
+					align-items: center;
+					padding: 30rpx;
+					color: #2FA8E1;
+					border-top-left-radius: 20rpx;
+					border-top-right-radius: 20rpx;
+
+					text {
+						margin-left: 10rpx;
+					}
+				}
+
+				&-qrcode {
+					background-color: #FFFFFF;
+					display: flex;
+					flex-direction: column;
+					align-items: center;
+					color: #999999;
+					font-size: 26rpx;
+					padding: 30rpx 50rpx;
+					border-width: 1rpx;
+					border-style: solid;
+					border-color: #CCCCCC;
+
+					&-desc {
+						margin-bottom: 30rpx;
+					}
+
+					&-box {
+						margin-top: 30rpx;
+						display: flex;
+						align-items: center;
+
+						text {
+							margin-left: 10rpx;
+							color: #666666;
+						}
+					}
+				}
+
+				&-footer {
+					background-color: #FFFFFF;
+					display: flex;
+					align-items: flex-start;
+					padding: 30rpx;
+					border-bottom-left-radius: 20rpx;
+					border-bottom-right-radius: 20rpx;
+
+					&-desc {
+						display: flex;
+						flex-direction: column;
+						margin-left: 10rpx;
+
+						&-no {
+							color: #999999;
+							font-size: 26rpx;
+						}
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_index/question/index.vue b/pages/sub_index/question/index.vue
new file mode 100644
index 0000000..dec6950
--- /dev/null
+++ b/pages/sub_index/question/index.vue
@@ -0,0 +1,113 @@
+<template>
+	<view class="question">
+		<!-- <view class="question-header">
+			<u-search placeholder="搜索问题关键词" v-model="keyword" :show-action="false" bg-color="#ffffff" @search="search"></u-search>
+		</view> -->
+		<view class="question-con">
+			<u-collapse arrow-color="#999999">
+				<u-collapse-item  v-for="(item, index) in list" :key="index">
+					<view slot="title" class="question-con-item-title">
+						<view class="question-con-item-title-index">{{ (index+1) < 10 ? '0'+(index + 1):(index+1)}}</view>
+						<text class="question-con-item-title-title">{{item.title}}</text>
+					</view>
+					<view class="question-con-item-con">
+						<text>{{item.content}}</text>
+					</view>
+				</u-collapse-item>
+			</u-collapse>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				keyword: "",
+				list:[]
+			}
+		},
+		methods: {
+			search(e){
+				uni.showToast({
+					icon: "none",
+					title: "搜索服务功能暂未开通",
+					duration: 1500
+				})
+			},
+			getQuestionList(){
+				let that = this
+				let params = {
+					pageno:1,
+					pagesize:20
+				}
+				that.$u.get("/i/advisory/list",params).then(res=>{
+					that.list = res.data.list
+					//console.log(that.list)
+				})
+			}
+		},
+		onLoad(){
+			let that = this
+			that.getQuestionList()
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.u-collapse-head{
+		padding: 30rpx 0;
+	}
+	.question {
+		overflow: hidden;
+		&-header {
+			width: 700rpx;
+			margin: 30rpx auto;
+			font-family: "PingFang-SC-Medium";
+		}
+		&-con{
+			background-color: #FFFFFF;
+			padding: 30rpx;
+			margin-top: 30rpx;
+			&-item{
+				&-con{
+					padding: 0 60rpx;
+					font-size: 28rpx;
+				}
+				&-title{
+					display: flex;
+					align-items: center;
+					
+					&-title{
+						font-size: 30rpx;
+					}
+					&-index{
+						display: flex;
+						justify-content: center;
+						align-items: center;
+						background-color: #2FA8E1;
+						padding: 10rpx;
+						color: #FFFFFF;
+						margin-right: 20rpx;
+						border-radius: 10rpx;
+						border-bottom-left-radius: 0;
+						position: relative;
+						font-size: 20rpx;
+						&::after{
+							content: "";
+							position: absolute;
+							width: 0;
+							height: 0;
+							bottom: -10rpx;
+							left: 0;
+							border-left: 12rpx #2FA8E1 solid;
+							border-top: 12rpx transparent solid;
+							border-right: 12rpx transparent solid;
+							border-bottom: 12rpx transparent solid;
+						}
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_index/scanView/index.vue b/pages/sub_index/scanView/index.vue
new file mode 100644
index 0000000..a9515a8
--- /dev/null
+++ b/pages/sub_index/scanView/index.vue
@@ -0,0 +1,67 @@
+<template>
+	<view>
+		<view class="status_bar"></view>
+		<web-view :webview-styles="webviewStyles" :src="src"></web-view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				src: "",
+				webviewStyles: {
+					progress: {
+						color: '#2B9939'
+					}
+				},
+				userid: ""
+			}
+		},
+		onLoad(option) {
+			let that = this
+			let userid = uni.getStorageSync("userid")
+			that.userid = userid
+			let url = option.url
+			// if (url.indexOf("?") > 0) {
+			// 	url = url + "&userid=" + userid
+			// } else {
+			// 	url = url + "?userid=" + userid
+			// }
+			that.src = url
+			//console.log(url)
+		},
+		onReady() {
+			let userid = uni.getStorageSync("userid")
+			var pages = getCurrentPages();
+			var page = pages[pages.length - 1];
+			var currentWebview = page.$getAppWebview();
+			var url = currentWebview.children()[0].getURL();
+			var wx = currentWebview.children()[0]
+			//console.log('=== url ===', url);
+			wx.addEventListener('loaded', function(e) {
+				//console.log('Loaded: ' + wx.getURL());
+				let newUrl = wx.getURL()
+				if (newUrl.indexOf("userid") > -1) {
+					//console.log(1)
+					return false
+				}
+				if (newUrl.indexOf("?") > 0) {
+					newUrl = newUrl + "&userid=" + userid
+				} else {
+					newUrl = newUrl + "?userid=" + userid
+				}
+				//console.log(newUrl)
+				wx.loadURL(newUrl)
+			}, false);
+		},
+		methods: {
+
+		},
+	}
+</script>
+
+<style scoped lang="scss">
+
+
+</style>
diff --git a/pages/sub_index/scanView/pay.vue b/pages/sub_index/scanView/pay.vue
new file mode 100644
index 0000000..25bce0a
--- /dev/null
+++ b/pages/sub_index/scanView/pay.vue
@@ -0,0 +1,33 @@
+<template>
+	<view class="loading">
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				src: ''
+			}
+		},
+		onLoad(options) {
+			let url = decodeURIComponent(options.url) 
+			let token = uni.getStorageSync('token')
+			let wv = plus.webview.create(url, 'webview_pay', {
+				top:'200px',
+				backButtonAutoControl:'close',
+				additionalHttpHeaders: {
+					Authorization: 'Bearer ' + token
+				}
+			})
+			setTimeout(() => {
+				wv.show()
+			}, 1000)
+		},
+	}
+</script>
+
+<style lang="scss" scoped>
+	.loading{
+	}
+</style>
diff --git a/pages/sub_medical/addPatient.vue b/pages/sub_medical/addPatient.vue
new file mode 100644
index 0000000..94cfda8
--- /dev/null
+++ b/pages/sub_medical/addPatient.vue
@@ -0,0 +1,79 @@
+<template>
+	<view class="addPatient">
+		<view class="addPatient-items">
+			<u-field v-model="name" label="姓名" placeholder="请输入姓名" required></u-field>
+			<u-field v-model="sex" label="性别" :placeholder="sexVal" required disabled @click="openPicker"></u-field>
+			<u-field v-model="cardno" label="证件号" placeholder="请输入身份证号" required></u-field>
+			<u-field v-model="mobile" label="联系电话" placeholder="请输入联系电话"></u-field>
+		</view>
+		<u-picker mode="selector" v-model="show" :default-selector="[0]" :range="list" @confirm="confirm"></u-picker>
+		<u-button @click="add_patient" :custom-style="addBtn">添加就诊人</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				name: '',
+				sex: '',
+				cardno: '',
+				mobile: '',
+				list:['男','女'],
+				sexVal: '请选择性别',
+				show:false,
+				addBtn: {
+					backgroundColor: ' #2FA8E1',
+					padding: '50rpx 0',
+					color: '#FFFFFF',
+					width: ' 600rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+					marginTop:'50rpx'
+				},
+			}
+		},
+		methods: {
+			openPicker(){
+				this.show = !this.show
+			},
+			confirm(e){
+				let index = e[0]
+				this.sexVal = this.list[index]
+				this.sex = index + 1 
+			},
+			add_patient(){
+				let that = this
+				let {name,sex,cardno,mobile} = that
+				if(name == '' || sex == '' || cardno == '' || mobile == ''){
+					uni.showModal({
+						title:'提示',
+						content:'请填写就诊人信息',
+						showCancel:false
+					})
+					return false
+				}
+				let params = {
+					name,sex,cardno,mobile,
+					hospitalcode:''
+				}
+				that.$u.post('/medicineapi/medicalcard/add',params).then(res=>{
+					console.log(res.data)
+				})
+			}
+		},
+		onLoad() {
+
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.addPatient {
+		font-family: "PingFang-SC-Medium";
+		&-items {
+			background-color: #FFFFFF;
+			margin-top: 30rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_medical/appointment.vue b/pages/sub_medical/appointment.vue
new file mode 100644
index 0000000..5de78b7
--- /dev/null
+++ b/pages/sub_medical/appointment.vue
@@ -0,0 +1,279 @@
+<template>
+	<view class="appointment">
+		<view class="appointment-header" @click="getLocal">
+			<u-image src="./images/app_bannar.png" width="100%" mode="widthFix"></u-image>
+			<u-icon name="map" color="#52B6E6" size="36" :label="local" class="appointment-header-icon"></u-icon>
+		</view>
+		<view class="appointment-search">
+			<u-search placeholder="搜索医院名称" v-model="hospial" :show-action="false" bg-color="#ffffff" @focus="toPath('/pages/sub_medical/hospital')"></u-search>
+		</view>
+		<view class="appointment-record">
+			<u-cell-group>
+				<u-cell-item title="我的挂号记录" value="查看更多" @click="toPath('/pages/sub_medical/record')"></u-cell-item>
+			</u-cell-group>
+			<view class="appointment-record-msg" v-if="record_list.length != 0">
+				<view class="appointment-record-msg-left">
+					<u-image src="/static/images/active/mrlfl.png" width="100" mode="widthFix"></u-image>
+				</view>
+				<view class="appointment-record-msg-center">
+					<view class="appointment-record-msg-center-item">
+						<text class="appointment-record-msg-center-item-title">就诊人员:</text>
+						<text class="appointment-record-msg-center-item-value">李小萌</text>
+					</view>
+					<view class="appointment-record-msg-center-item">
+						<text class="appointment-record-msg-center-item-title">就诊医院:</text>
+						<text class="appointment-record-msg-center-item-value">大理市第二人民医院</text>
+					</view>
+					<view class="appointment-record-msg-center-item">
+						<text class="appointment-record-msg-center-item-title">就诊科室:</text>
+						<text class="appointment-record-msg-center-item-value">普外科</text>
+					</view>
+					<view class="appointment-record-msg-center-item">
+						<text class="appointment-record-msg-center-item-title">就诊时间:</text>
+						<text class="appointment-record-msg-center-item-value">2020-10-27【上午】</text>
+					</view>
+				</view>
+				<view class="appointment-record-msg-right">
+					<text class="appointment-record-msg-status">挂号成功</text>
+				</view>
+			</view>
+			<view class="appointment-record-nomsg" v-else>
+				<text>暂无挂号记录</text>
+			</view>
+			<!-- <view class="appointment-record-btn">
+				<u-button :plain="true" size="mini" type="primary" shape="circle">取消预约</u-button>
+			</view> -->
+		</view>
+		<view class="appointment-hospital">
+			<u-cell-group>
+				<u-cell-item title="本地医院" value="查看更多" @click="toPath('/pages/sub_medical/hospital')"></u-cell-item>
+			</u-cell-group>
+			<view class="appointment-hospital-msg" v-if="hospital_list.length != 0">
+				<view class="appointment-hospital-msg-box" @click="toPath('/pages/sub_medical/outpatient')" v-for="(v,i) in hospital_list" :key="i">
+					<view class="appointment-hospital-msg-left">
+						<u-image :src="v.src" width="100" mode="widthFix"></u-image>
+					</view>
+					<view class="appointment-hospital-msg-right">
+						<view class="appointment-hospital-msg-right-item">
+							<text class="appointment-hospital-msg-right-item-logo">{{v.level}}</text>
+							<text class="appointment-hospital-msg-right-item-value" style="color: #333333;font-size: 32rpx;">{{v.name}}</text>
+						</view>
+						<view class="appointment-hospital-msg-right-item">
+							<text class="appointment-hospital-msg-right-item-title">地理位置:</text>
+							<text class="appointment-hospital-msg-right-item-value">{{v.address}}</text>
+						</view>
+						<view class="appointment-hospital-msg-right-item">
+							<text class="appointment-hospital-msg-right-item-title">门诊时间:</text>
+							<text class="appointment-hospital-msg-right-item-value">{{v.time}}</text>
+						</view>
+					</view>
+				</view>
+			</view>
+			<view class="appointment-hospital-nomsg" v-else>
+				<text>暂无医院数据</text>
+			</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				local: '大理',
+				hospial: '',
+				hospital_list:[],
+				record_list:[]
+			}
+		},
+		onLoad() {
+			this.get_hospital_list()
+			this.getLocal()
+		},
+		methods: {
+			getLocal() {
+				let that = this
+				uni.getLocation({
+					type: 'gcj02',
+					geocode: true,
+					success(res) {
+						console.log(res)
+						// #ifdef APP-PLUS
+						that.local = res.address.city
+						// #endif
+					},
+					fail(ret){
+						that.local = '获取位置失败'
+						console.log(ret)
+					}
+				})
+			},
+			get_hospital_list(){
+				let that = this
+				let params = {
+					pageno:1,
+					pagesize:3,
+					name:''
+				}
+				that.$u.get('/medicineapi/hospital/list',params).then(res=>{
+					that.hospital_list = res.data.list
+					console.log(res.data.list)
+				})
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	/deep/.u-btn--primary--plain {
+		background-color: #FFFFFF !important;
+	}
+
+	.u-cell {
+		padding: 30rpx 20rpx;
+	}
+
+	/deep/.u-cell__right-icon-wrap {
+		height: 54rpx;
+	}
+
+	uni-button {
+		margin-left: 0;
+		margin-right: 0;
+	}
+
+	.appointment {
+		font-family: "PingFang-SC-Medium";
+
+		&-header {
+			position: relative;
+
+			&-icon {
+				position: absolute;
+				top: 20rpx;
+				left: 20rpx;
+			}
+		}
+
+		&-search {
+			padding: 30rpx;
+		}
+
+		&-record {
+			background-color: #FFFFFF;
+			&-nomsg{
+				display: flex;
+				justify-content: center;
+				align-items: center;
+				padding: 50rpx 30rpx;
+			}
+
+			&-msg {
+				padding: 30rpx 10rpx;
+				display: flex;
+				justify-content: space-between;
+
+				// align-items: center;
+				&-left {
+					flex: 1;
+					display: flex;
+					justify-content: center;
+				}
+
+				&-center {
+					flex: 3;
+
+					&-item {
+						padding: 0 0 10rpx;
+
+						&-title {
+							color: #909399;
+						}
+					}
+				}
+
+				&-right {
+					display: flex;
+					justify-content: center;
+					flex: 1;
+					color: #3DC64F;
+
+					&-item {}
+				}
+			}
+
+			&-btn {
+				padding: 0rpx 30rpx 30rpx;
+				display: flex;
+				justify-content: flex-end;
+			}
+		}
+
+		&-hospital {
+			background-color: #FFFFFF;
+			margin: 30rpx 0;
+			
+			&-nomsg{
+				display: flex;
+				justify-content: center;
+				align-items: center;
+				padding: 50rpx 30rpx;
+			}
+
+			&-msg {
+				&-box {
+					display: flex;
+					justify-content: space-between;
+					padding: 30rpx 10rpx;
+				}
+
+				&-left {
+					flex: 1;
+					display: flex;
+					justify-content: center;
+				}
+
+				&-right {
+					display: flex;
+					flex: 4;
+					flex-direction: column;
+
+					&-item {
+						padding: 0 0 10rpx;
+						display: flex;
+						align-items: center;
+
+						&-logo {
+							display: inline-block;
+							background-color: #17C46F;
+							padding: 4rpx;
+							color: #FFFFFF;
+							font-size: 20rpx;
+							border-radius: 5rpx;
+							margin-right: 10rpx;
+						}
+
+						&-title {
+							display: inline-block;
+							// flex: 1;
+							width: 140rpx;
+							color: #B5B5B5;
+							font-size: 26rpx;
+						}
+
+						&-value {
+							display: inline-block;
+							// flex: 4;
+							color: #B5B5B5;
+							width: 400rpx;
+							white-space: nowrap;
+							text-overflow: ellipsis;
+							overflow: hidden;
+							font-size: 28rpx;
+						}
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_medical/cashFlow.vue b/pages/sub_medical/cashFlow.vue
new file mode 100644
index 0000000..efe1ff2
--- /dev/null
+++ b/pages/sub_medical/cashFlow.vue
@@ -0,0 +1,153 @@
+<template>
+	<view class="cashFlow">
+		<view style="padding: 30rpx 0;">
+			<view class="cashFlow-header">
+				<view :class="'cashFlow-header-items left ' + (leftOright?'color':'')" @click="changeTurnoverList(true)">待缴费</view>
+				<view :class="'cashFlow-header-items right ' + (leftOright?'':'color')" @click="changeTurnoverList(false)">已缴费</view>
+			</view>
+		</view>
+		<view v-if="leftOright">
+			<scroll-view scroll-y :enable-back-to-top="true" @scrolltolower="" class="scrollView">
+				<view class="cashFlow-ul">
+					<view class="cashFlow-ul-item">
+						<view class="cashFlow-ul-item-left">
+							<view class="cashFlow-ul-item-left-top">
+								<u-image src="./images/pay.png" width="80" height="80"></u-image>
+								<text>挂号费</text>
+							</view>
+							<view class="cashFlow-ul-item-left-bottom">
+								<text class="cashFlow-ul-item-left-bottom-bold">01</text>
+								<text class="cashFlow-ul-item-left-bottom-normal">天内缴费,截止日期2020/10/28 23:59:59</text>
+							</view>
+						</view>
+						<view class="cashFlow-ul-item-right">
+							<text>¥23.5</text>
+						</view>
+					</view>
+				</view>
+			</scroll-view>
+		</view>
+		<view v-if="!leftOright">
+			<scroll-view scroll-y :enable-back-to-top="true" @scrolltolower="" class="scrollView">
+				<view class="cashFlow-ul">
+					<view class="cashFlow-ul-item">
+						<view class="cashFlow-ul-item-left">
+							<view class="cashFlow-ul-item-left-top">
+								<u-image src="./images/pay.png" width="80" height="80"></u-image>
+								<text>挂号费</text>
+							</view>
+							<view class="cashFlow-ul-item-left-bottom">
+								<text class="cashFlow-ul-item-left-bottom-normal">缴费日期:</text>
+								<text class="cashFlow-ul-item-left-bottom-normal">2020-10-28 12:30:59</text>
+							</view>
+						</view>
+						<view class="cashFlow-ul-item-right">
+							<text>¥23.5</text>
+						</view>
+					</view>
+				</view>
+			</scroll-view>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				leftOright: true
+			}
+		},
+		methods: {
+			changeTurnoverList(e) {
+				this.leftOright = e
+			},
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.scrollView{
+		height: calc(100vh - 130rpx - 100rpx);
+	}
+	.cashFlow {
+		font-family: "PingFang-SC-Medium";
+		&-header {
+			width: 80%;
+			display: flex;
+			justify-content: center;
+			align-items: center;
+			border-radius: 50rpx;
+			margin: 0rpx auto;
+
+			&-items {
+				width: 50%;
+				text-align: center;
+				background-color: #ffffff;
+				padding: 20rpx;
+				color: #999999;
+				border-top: 2rpx solid #F1F1F1;
+				border-bottom: 2rpx solid #F1F1F1;
+			}
+			.left {
+				border-top-left-radius: 50rpx;
+				border-bottom-left-radius: 50rpx;
+				border-left: 2rpx solid #F1F1F1;
+			}
+			
+			.right {
+				border-top-right-radius: 50rpx;
+				border-bottom-right-radius: 50rpx;
+				border-right: 2rpx solid #F1F1F1;
+			}
+			
+			.color {
+				background-color: #3599fb;
+				color: #ffffff;
+				padding: 20rpx;
+				border: 2rpx solid transparent;
+			}
+		}
+		&-ul{
+			padding: 0 20rpx;
+			&-item{
+				background-color: #FFFFFF;
+				display: flex;
+				justify-content: space-between;
+				align-items: center;
+				padding: 30rpx 20rpx;
+				border-radius: 10rpx;
+				&-left{
+					display:  flex;
+					flex-direction: column;
+					justify-content: space-between;
+					&-top{
+						display: flex;
+						align-items: center;
+						text{
+							font-size: 36rpx;
+							margin-left: 10rpx;
+							font-weight: bold;
+						}
+					}
+					&-bottom{
+						margin-top: 20rpx;
+						&-bold{
+							font-size: 32rpx;
+							font-weight: bold;
+						}
+						&-normal{
+							color: #a1a1a1;
+						}
+					}
+				}
+				&-right{
+					font-size: 40rpx;
+					color: #FF6F6F;
+					font-weight: bold;
+				}
+			}
+		}
+		
+	}
+</style>
diff --git a/pages/sub_medical/confirm.vue b/pages/sub_medical/confirm.vue
new file mode 100644
index 0000000..155b690
--- /dev/null
+++ b/pages/sub_medical/confirm.vue
@@ -0,0 +1,122 @@
+<template>
+	<view class="confirm">
+		<view class="confirm-header">
+			<u-image src="./images/hospital.png" width="100" mode="widthFix"></u-image>
+			<view class="confirm-header-partmsg">
+				<text class="confirm-header-partmsg-title">心内科</text>
+				<text class="confirm-header-partmsg-subtitle">大理市第一人民医院(总院)</text>
+			</view>
+		</view>
+		<view class="confirm-part">
+			<view class="confirm-part-item">
+				<text class="confirm-part-item-title">就诊时间:</text>
+				<text class="confirm-part-item-subtitle">2020-10-20/周一/上午</text>
+			</view>
+			<view class="confirm-part-item">
+				<text class="confirm-part-item-title">就诊地点:</text>
+				<text class="confirm-part-item-subtitle">云南省大理市大苏打大撒</text>
+			</view>
+		</view>
+		<view class="confirm-member">
+			<u-cell-group>
+				<u-cell-item title="选择就诊人" value="就诊人管理" :value-style="style" @click="toPath('/pages/sub_medical/patient')"></u-cell-item>
+			</u-cell-group>
+			<view class="confirm-member-msg">
+				<u-field label="就诊人员" placeholder="李小明/男/24岁" disabled required :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				<u-field label="证件号码" placeholder="32323423423****3123" disabled required :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				<u-field label="就诊卡号" placeholder="321321441" disabled required :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				<u-field label="联系电话" placeholder="130****3322" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+			</view>
+		</view>
+		<u-button :custom-style="btn">提交预约</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				style: {
+					color: '#2FA8E1'
+				},
+				mstyle:'color:#333333',
+				btn: {
+					backgroundColor: ' #2FA8E1',
+					padding: '50rpx 0',
+					color: '#FFFFFF',
+					width: ' 650rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+					marginTop:'50rpx'
+				},
+			}
+		},
+		onLoad() {
+
+		},
+		methods: {
+
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.u-field{
+		color: #a1a1a1;
+	}
+	.u-cell {
+		padding: 30rpx 10rpx;
+	}
+	.u-cell__right-icon-wrap {
+		height: 54rpx;
+	}
+	.confirm {
+		font-family: "PingFang-SC-Medium";
+
+		&-header {
+			padding: 10rpx;
+			background-color: #FFFFFF;
+			display: flex;
+			align-items: center;
+			margin-bottom: 3rpx;
+
+			&-partmsg {
+				margin-left: 30rpx;
+				display: flex;
+				flex-direction: column;
+
+				&-title {
+					font-size: 32rpx;
+					font-weight: bold;
+					margin-bottom: 6rpx;
+				}
+
+				&-subtitle {
+					color: #6A6A6A;
+				}
+			}
+		}
+
+		&-part {
+			background-color: #FFFFFF;
+			padding: 30rpx 20rpx;
+
+			&-item {
+				margin-bottom: 10rpx;
+
+				&-title {
+					color: #A1A1A1;
+				}
+
+				&-subtitle {
+					color: #333333;
+				}
+			}
+		}
+
+		&-member {
+			background-color: #FFFFFF;
+			margin: 30rpx 0;
+		}
+	}
+</style>
diff --git a/pages/sub_medical/hospital.vue b/pages/sub_medical/hospital.vue
new file mode 100644
index 0000000..1b66fc1
--- /dev/null
+++ b/pages/sub_medical/hospital.vue
@@ -0,0 +1,167 @@
+<template>
+	<view class="hospital">
+		<view class="hospital-search">
+			<u-search placeholder="搜索医院名称" v-model="hospial" :show-action="false" bg-color="#ffffff" :focus="isFocus" @search="get_hospital_list"></u-search>
+		</view>
+		<view class="hospital-drop">
+			<view class="hospital-drop-item">
+				<u-dropdown border-bottom class="drop">
+					<u-dropdown-item v-model="value1" title="医院排序" :options="options1"></u-dropdown-item>
+				</u-dropdown>
+			</view>
+		</view>
+		<view class="hospital-ul">
+			<view class="hospital-ul-noitem" v-if="hospital_list.length == 0">
+				<text>{{notice}}</text>
+			</view>
+			<view class="hospital-ul-item" v-else >
+				<view class="hospital-ul-item-box" v-for="(v,i) in hospital_list" :key="i">
+					<view class="hospital-ul-item-left">
+						<u-image :src="v.src" width="100" mode="widthFix"></u-image>
+					</view>
+					<view class="hospital-ul-item-right">
+						<view class="hospital-ul-item-right-item">
+							<text class="hospital-ul-item-right-item-logo">{{v.level}}</text>
+							<text class="hospital-ul-item-right-item-value" style="color: #333333;font-size: 32rpx;">{{v.name}}</text>
+						</view>
+						<view class="hospital-ul-item-right-item">
+							<text class="hospital-ul-item-right-item-title">地理位置:</text>
+							<text class="hospital-ul-item-right-item-value">{{v.address}}</text>
+						</view>
+						<view class="hospital-ul-item-right-item">
+							<text class="hospital-ul-item-right-item-title">门诊时间:</text>
+							<text class="hospital-ul-item-right-item-value">{{v.time}}</text>
+						</view>
+					</view>
+				</view>
+			</view>
+			
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				isFocus: true,
+				hospial: '',
+				value1: 1,
+				options1: [{
+					label: '默认排序',
+					value: 1,
+				}],
+				hospital_list: [],
+				notice:'暂无数据'
+			}
+		},
+		onLoad() {
+
+		},
+		methods: {
+			get_hospital_list() {
+				let that = this
+				let name = that.hospial
+				let params = {
+					pageno: 1,
+					pagesize: 10,
+					name: name
+				}
+				that.$u.get('/medicineapi/hospital/list', params).then(res => {
+					that.hospital_list = res.data.list
+					that.notice = '没有搜索到此关键词'
+					console.log(res.data.list)
+				})
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.drop {
+		/deep/.u-dropdown__menu__item {
+			padding: 0 30rpx;
+			justify-content: flex-start;
+		}
+	}
+
+	.hospital {
+		font-family: "PingFang-SC-Medium";
+
+		&-search {
+			padding: 30rpx;
+		}
+
+		&-drop {
+			background-color: #FFFFFF;
+
+			&-item {}
+		}
+
+		&-ul {
+			background-color: #FFFFFF;
+
+			&-noitem {
+				display: flex;
+				justify-content: center;
+				padding: 50rpx 30rpx;
+				align-items: center;
+			}
+
+			&-item {
+				&-box {
+					display: flex;
+					justify-content: space-between;
+					padding: 30rpx 10rpx;
+				}
+
+				&-left {
+					flex: 1;
+					display: flex;
+					justify-content: center;
+				}
+
+				&-right {
+					display: flex;
+					flex: 4;
+					flex-direction: column;
+
+					&-item {
+						padding: 0 0 10rpx;
+						display: flex;
+						align-items: center;
+
+						&-logo {
+							display: inline-block;
+							background-color: #17C46F;
+							padding: 4rpx;
+							color: #FFFFFF;
+							font-size: 20rpx;
+							border-radius: 5rpx;
+							margin-right: 10rpx;
+						}
+
+						&-title {
+							display: inline-block;
+							// flex: 1;
+							width: 140rpx;
+							color: #B5B5B5;
+							font-size: 26rpx;
+						}
+
+						&-value {
+							display: inline-block;
+							// flex: 4;
+							color: #B5B5B5;
+							width: 400rpx;
+							white-space: nowrap;
+							text-overflow: ellipsis;
+							overflow: hidden;
+							font-size: 28rpx;
+						}
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_medical/images/app_bannar.png b/pages/sub_medical/images/app_bannar.png
new file mode 100644
index 0000000..959dc59
--- /dev/null
+++ b/pages/sub_medical/images/app_bannar.png
Binary files differ
diff --git a/pages/sub_medical/images/cush.png b/pages/sub_medical/images/cush.png
new file mode 100644
index 0000000..5f0697e
--- /dev/null
+++ b/pages/sub_medical/images/cush.png
Binary files differ
diff --git a/pages/sub_medical/images/hospital.png b/pages/sub_medical/images/hospital.png
new file mode 100644
index 0000000..50fee69
--- /dev/null
+++ b/pages/sub_medical/images/hospital.png
Binary files differ
diff --git a/pages/sub_medical/images/pat_bannar.png b/pages/sub_medical/images/pat_bannar.png
new file mode 100644
index 0000000..e1381a8
--- /dev/null
+++ b/pages/sub_medical/images/pat_bannar.png
Binary files differ
diff --git a/pages/sub_medical/images/pay.png b/pages/sub_medical/images/pay.png
new file mode 100644
index 0000000..0265784
--- /dev/null
+++ b/pages/sub_medical/images/pay.png
Binary files differ
diff --git a/pages/sub_medical/images/report.png b/pages/sub_medical/images/report.png
new file mode 100644
index 0000000..06db6e5
--- /dev/null
+++ b/pages/sub_medical/images/report.png
Binary files differ
diff --git a/pages/sub_medical/images/success.png b/pages/sub_medical/images/success.png
new file mode 100644
index 0000000..86386db
--- /dev/null
+++ b/pages/sub_medical/images/success.png
Binary files differ
diff --git a/pages/sub_medical/outpatient.vue b/pages/sub_medical/outpatient.vue
new file mode 100644
index 0000000..6eac58a
--- /dev/null
+++ b/pages/sub_medical/outpatient.vue
@@ -0,0 +1,178 @@
+<template>
+	<view class="outpatient">
+		<view class="outpatient-headerbox">
+			<view class="outpatient-header">
+				<view class="outpatient-header-img">
+					<u-image src="/static/images/active/mrlfl.png" width="120" mode="widthFix"></u-image>
+				</view>
+				<view class="outpatient-header-msg">
+					<text class="outpatient-header-msg-title">大理市第一人民医院</text>
+					<text class="outpatient-header-msg-logo">三甲</text>
+					<text class="outpatient-header-msg-to">热门科室:皮肤科、普外科</text>
+				</view>
+			</view>
+			<u-icon name="map" color="#52B6E6" size="36" :label="local" class="outpatient-headerbox-icon" label-color="#A1A1A1"></u-icon>
+			<u-icon name="clock" color="#52B6E6" size="36" :label="time" class="outpatient-headerbox-icon" label-color="#A1A1A1"></u-icon>
+			<u-icon name="phone" color="#52B6E6" size="36" :label="tel" class="outpatient-headerbox-icon" label-color="#A1A1A1"></u-icon>
+		</view>
+		<view class="outpatient-search">
+			<u-search placeholder="搜索科室名称" v-model="part" :show-action="false" bg-color="#ffffff"></u-search>
+		</view>
+		<view class="outpatient-kinds">
+			<view class="outpatient-kinds-left">
+				<scroll-view scroll-y="true" class="scrollView" :style="{height:height+'px'}">
+					<view class="outpatient-kinds-left-item">
+						<view class="outpatient-kinds-left-item-line"> </view>
+						<u-cell-item title="全部" :arrow="false" bg-color="#ffffff" :title-style="style"></u-cell-item>
+					</view>
+				</scroll-view>
+			</view>
+			<view class="outpatient-kinds-right">
+				<scroll-view scroll-y="true" class="scrollView" :style="{height:height+'px'}">
+					<view class="outpatient-kinds-right-item" @click="toPath('/pages/sub_medical/queryDate')">
+						<u-cell-item title="心内科" :arrow="false"></u-cell-item>
+					</view>
+					<view class="outpatient-kinds-right-item">
+						<u-cell-item title="心内科" :arrow="false"></u-cell-item>
+					</view>
+					<view class="outpatient-kinds-right-item">
+						<u-cell-item title="心内科" :arrow="false"></u-cell-item>
+					</view>
+					<view class="outpatient-kinds-right-item">
+						<u-cell-item title="心内科" :arrow="false"></u-cell-item>
+					</view>
+					<view class="outpatient-kinds-right-item">
+						<u-cell-item title="心内科" :arrow="false"></u-cell-item>
+					</view>
+				</scroll-view>
+			</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				local: '云南省大理市下关泰安路36号',
+				time: '上午8:00-11:30;下午14:00-17:30 周六、日照常。',
+				tel: '021-3123320',
+				part: '',
+				height: '',
+				style: {
+					color: '#40AFE3',
+					fontWeight: 'bold'
+				}
+			}
+		},
+		onLoad() {
+			this.getSrcollViewHeight()
+		},
+		methods: {
+			getSrcollViewHeight() {
+				let winHeight
+				let that = this
+				uni.getSystemInfo({
+					success: function(res) {
+						winHeight = res.windowHeight
+					}
+				});
+				//console.log(winHeight)
+				const query = uni.createSelectorQuery().in(that);
+				query.select('.outpatient-search').boundingClientRect(data => {
+					console.log(data)
+					if (!data) {
+						setTimeout(() => {
+							that.getSrcollViewHeight()
+						}, 10)
+						return
+					}
+					that.height = winHeight - data.top - data.height
+					// that.height = (data.bottom - data.height)*2
+				}).exec();
+			},
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.u-cell{
+		padding: 20rpx 32rpx;
+	}
+	.outpatient {
+		font-family: "PingFang-SC-Medium";
+
+		&-headerbox {
+			background-color: #FFFFFF;
+			padding: 30rpx 20rpx;
+
+			&-icon {
+				margin-bottom: 10rpx;
+				font-size: 28rpx;
+			}
+		}
+
+		&-header {
+			display: flex;
+			align-items: center;
+			margin-bottom: 30rpx;
+
+			&-img {
+				justify-content: center;
+
+			}
+
+			&-msg {
+				margin-left: 20rpx;
+				display: flex;
+				flex-direction: column;
+
+				&-title {
+					font-size: 32rpx;
+				}
+
+				&-logo {
+					display: inline-block;
+					background-color: #17C46F;
+					padding: 4rpx;
+					width: 80rpx;
+					color: #FFFFFF;
+					text-align: center;
+					font-size: 20rpx;
+					border-radius: 5rpx;
+					margin: 10rpx 0;
+				}
+
+				&-to {
+					color: #A1A1A1;
+				}
+			}
+
+		}
+
+		&-search {
+			padding: 30rpx;
+		}
+		&-kinds {
+			display: flex;
+			&-left {
+				flex: 1;
+				&-item {
+					display: flex;
+					background-color: #FFFFFF;
+					&-line {
+						width: 10rpx;
+						height: 110rpx;
+						background-color: #40AFE3;
+					}
+				}
+			}
+
+			&-right {
+				flex: 3;
+				background-color: #FFFFFF;
+			}
+		}
+
+	}
+</style>
diff --git a/pages/sub_medical/patient.vue b/pages/sub_medical/patient.vue
new file mode 100644
index 0000000..f6d549c
--- /dev/null
+++ b/pages/sub_medical/patient.vue
@@ -0,0 +1,102 @@
+<template>
+	<view class="patient">
+		<view class="patient-bgc">
+			<!-- #ifdef APP-PLUS -->
+			<u-navbar title="就诊人管理" :background="background" title-color="#ffffff" :border-bottom="false" back-icon-color="#ffffff"></u-navbar>
+			<!-- #endif -->
+		</view>
+		<view class="patient-ul">
+			<view class="patient-ul-item">
+				<u-field label="当前就诊人" placeholder="" disabled input-align="right" label-width="150">
+					<u-button size="mini" slot="right" plain type="primary" shape="circle" @click="deleteMenber" :custom-style="btn">删除</u-button>
+				</u-field>
+				<view class="patient-ul-item-msg">
+					<u-field label="就诊人员" placeholder="李小明/男/24岁" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+					<u-field label="证件号码" placeholder="2324324*****323123" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+					<u-field label="就诊卡号" placeholder="30230248912" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+					<u-field label="联系电话" placeholder="131****3421" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				</view>
+			</view>
+			<view class="patient-ul-item">
+				<u-field label="就诊人" placeholder="" disabled input-align="right" label-width="150">
+					<u-button size="mini" slot="right" type="primary" plain shape="circle" @click="deleteMenber" :custom-style="btn">删除</u-button>
+				</u-field>
+				<view class="patient-ul-item-msg">
+					<u-field label="就诊人员" placeholder="李小明/男/24岁" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+					<u-field label="证件号码" placeholder="2324324*****323123" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+					<u-field label="就诊卡号" placeholder="30230248912" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+					<u-field label="联系电话" placeholder="131****3421" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				</view>
+			</view>
+		</view>
+		<u-button @click="" :custom-style="addBtn">添加就诊人</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				background: {
+					'background': 'no'
+				},
+				btn:{
+					padding:'0 30rpx',
+					background:'#ffffff'
+				},
+				addBtn: {
+					backgroundColor: ' #2FA8E1',
+					padding: '50rpx 0',
+					color: '#FFFFFF',
+					width: ' 600rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+				},
+				mstyle:'color:#333333',
+			}
+		},
+		onLoad() {
+
+		},
+		methods: {
+			deleteMenber(){
+				let that = this
+				let cardid = '123'
+				that.$u.post('/medicineapi/medicalcard/delete/' + cardid).then(res=>{
+					console.log(res.data)
+				})
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	/deep/.u-btn--primary--plain{
+		background-color: #FFFFFF !important;
+	}
+	.patient {
+		font-family: "PingFang-SC-Medium";
+		&-bgc {
+			background-image: url(./images/pat_bannar.png);
+			background-position: center;
+			background-repeat: no-repeat;
+			background-size: cover;
+			padding-bottom: 340rpx;
+		}
+
+		&-ul {
+			margin-top: -270rpx;
+			padding: 0 30rpx;
+			&-item{
+				margin-bottom: 30rpx;
+				background-color: #FFFFFF;
+				border-radius: 10rpx;
+				&-msg{
+					.u-field{
+						color: #a1a1a1;
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_medical/pay.vue b/pages/sub_medical/pay.vue
new file mode 100644
index 0000000..751d7d3
--- /dev/null
+++ b/pages/sub_medical/pay.vue
@@ -0,0 +1,57 @@
+<template>
+	<view class="pay">
+		<u-cell-group>
+			<u-cell-item title="挂号费" :title-style="tstyle" :arrow="false">
+				<u-image slot="icon" src="./images/cush.png" width="60" height="60" mode="aspectFit"></u-image>
+			</u-cell-item>
+			<u-cell-item title="缴费金额"  :arrow="false" value="23.50元" :value-style="vstyle"></u-cell-item>
+		</u-cell-group>
+		<u-cell-group>
+			<u-cell-item title="商户名称"  :arrow="false" value="大理市第一人民医院"></u-cell-item>
+			<u-cell-item title="截止日期"  :arrow="false" value="2020/10/28 23:29:29"></u-cell-item>
+			<u-cell-item title="交易状态"  :arrow="false" value="未支付"></u-cell-item>
+		</u-cell-group>
+		<u-button @click="" :custom-style="payBtn">立即支付</u-button>
+	</view>
+</template>
+
+<script>
+	export default{
+		data(){
+			return{
+				tstyle: {
+					marginLeft: '10rpx',
+					fontWeight: 'bold'
+				},
+				vstyle: {
+					color: '#FF6F6F'
+				},
+				payBtn: {
+					backgroundColor: ' #2FA8E1',
+					padding: '50rpx 0',
+					color: '#FFFFFF',
+					width: ' 600rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+					marginTop: '50rpx'
+				},
+			}
+		},
+		methods:{
+			
+		},
+		onLoad(){
+			
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.u-cell-box{
+		margin-bottom: 30rpx;
+	}
+	.pay{
+		font-family: "PingFang-SC-Medium";
+	}
+	
+</style>
diff --git a/pages/sub_medical/payResult.vue b/pages/sub_medical/payResult.vue
new file mode 100644
index 0000000..bd09b48
--- /dev/null
+++ b/pages/sub_medical/payResult.vue
@@ -0,0 +1,80 @@
+<template>
+	<view class="payResult">
+		<view class="payResult-status" v-if="msg.billstatus ==2">
+			<icon type="success" size="60" color="#3599FB"></icon>
+			<text class="payResult-status-text">支付成功</text>
+		</view>
+		<view class="payResult-status" v-if="msg.billstatus !=2">
+			<icon type="warn" size="60"></icon>
+			<text class="payResult-status-text">支付失败</text>
+		</view>
+		<view class="payResult-money" v-if="msg.billstatus ==2"><text>-¥{{msg.amount?msg.amount:'0.00'}}</text></view>
+		<view class="payResult-msg">
+			<u-cell-group>
+				<u-cell-item title="商户名" :value="msg.shopname?msg.shopname:'未知商户'" :arrow="false" bg-color="#FFFFFF"></u-cell-item>
+				<u-cell-item title="交易方式" :value="msg.billname?msg.billname:'未知方式'" :arrow="false" bg-color="#FFFFFF"></u-cell-item>
+				<u-cell-item title="交易时间" :value="msg.paytime?msg.paytime:'未知时间'" :arrow="false" bg-color="#FFFFFF"></u-cell-item>
+				<u-cell-item title="订单号" :value="msg.refno?msg.refno:'未知订单号'" :arrow="false" bg-color="#FFFFFF"></u-cell-item>
+			</u-cell-group>
+		</view>
+		<u-button class="btn":custom-style="btn"  @tap="goBack">返回首页</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				msg: {},
+				btn: {
+					backgroundColor: ' #2FA8E1',
+					padding: '50rpx 0',
+					color: '#FFFFFF',
+					width: ' 600rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+					marginTop: '50rpx'
+				}
+			}
+		},
+		onLoad(options) {
+			let that = this;
+			if (options.data) {
+				let msg = JSON.parse(options.data);
+				msg.amount = msg.amount.toFixed(2);
+				that.msg = msg
+			}
+		},
+		methods: {
+			goBack() {
+				uni.switchTab({
+					url: '/pages/sub_tabbar/index'
+				});
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.payResult {
+		background-color: #FFFFFF;
+		height: 100vh;
+		box-sizing: border-box;
+		padding: 30rpx 0;
+		display: flex;
+		flex-direction: column;
+		&-status{
+			display: flex;
+			justify-content: center;
+			align-items: center;
+			flex-direction: column;
+			&-text{
+				font-size: 40rpx;
+				margin-top: 30rpx;
+			}
+		}
+		&-msg{
+			margin-top: 50rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_medical/queryDate.vue b/pages/sub_medical/queryDate.vue
new file mode 100644
index 0000000..d2ff8d8
--- /dev/null
+++ b/pages/sub_medical/queryDate.vue
@@ -0,0 +1,129 @@
+<template>
+	<view class="queryDate">
+		<view class="queryDate-header">
+			<u-image src="./images/hospital.png" width="120" mode="widthFix"></u-image>
+			<view class="queryDate-header-partmsg">
+				<text class="queryDate-header-partmsg-title">心内科</text>
+				<text class="queryDate-header-partmsg-subtitle">大理市第一人民医院(总院)</text>
+			</view>
+		</view>
+		<view class="queryDate-query">
+			<text class="queryDate-query-title">排班信息</text>
+			<u-line  margin="30rpx 0 10rpx"/>
+			<view class="queryDate-query-calendar">
+				<my-calendar @change="getDate"></my-calendar>
+			</view>
+			<u-line></u-line>
+			<view class="queryDate-query-cell">
+				<text class="queryDate-query-cell-title">就诊时间:上午</text>
+				<view class="queryDate-query-cell-num">
+					<text class="queryDate-query-cell-num-now" :class="isMorFull?'err':'success'">21</text>
+					<text class="queryDate-query-cell-num-all">/40</text>
+				</view>
+				<u-button size="mini" :type="isMorFull?'':'primary'" plain shape="circle" :disabled="isMorFull"
+				@click="toPath('/pages/sub_medical/confirm')">{{isMorFull?'已约满':'可预约'}}</u-button>
+			</view>
+			<u-line></u-line>
+			<view class="queryDate-query-cell">
+				<text class="queryDate-query-cell-title">就诊时间:下午</text>
+				<view class="queryDate-query-cell-num">
+					<text class="queryDate-query-cell-num-now " :class="isAftFull?'err':'success'">21</text>
+					<text class="queryDate-query-cell-num-all">/40</text>
+				</view>
+				<u-button size="mini" :type="isAftFull?'':'primary'" plain shape="circle" :disabled="isAftFull">{{isAftFull?'已约满':'可预约'}}</u-button>
+			</view>
+			<u-line></u-line>
+			<view class="queryDate-query-cell">
+				<text class="queryDate-query-cell-title">就诊时间:晚上</text>
+				<view class="queryDate-query-cell-num">
+					<text class="queryDate-query-cell-num-now" :class="isEveFull?'err':'success'">40</text>
+					<text class="queryDate-query-cell-num-all">/40</text>
+				</view>
+				<u-button size="mini" :type="isEveFull?'':'primary'" plain shape="circle" :disabled="isEveFull">{{isEveFull?'已约满':'可预约'}}</u-button>
+			</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	import myCalendar from './z_components/calendar/calendar.vue'
+	export default {
+		components: {
+			myCalendar,
+		},
+		data() {
+			return {
+				isEveFull:true,
+				isAftFull:false,
+				isMorFull:false,
+			}
+		},
+		methods: {
+			getDate(e){
+				console.log(e)
+			}
+		},
+		onLoad() {
+
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	/deep/.u-btn--primary--plain{
+		background-color: #FFFFFF !important;
+	}
+	uni-button{
+		margin-left: 0;
+		margin-right: 0;
+	}
+	.err{
+		color: #FF5353;
+	}
+	.success{
+		color: #17C46F;
+	}
+	.queryDate {
+		font-family: "PingFang-SC-Medium";
+
+		&-header {
+			padding: 0 30rpx;
+			background-color: #FFFFFF;
+			display: flex;
+			align-items: center;
+
+			&-partmsg {
+				margin-left: 30rpx;
+				display: flex;
+				flex-direction: column;
+
+				&-title {
+					font-size: 32rpx;
+					font-weight: bold;
+					margin-bottom: 6rpx;
+				}
+
+				&-subtitle {
+					color: #6A6A6A;
+				}
+			}
+		}
+		&-query{
+			margin-top: 10rpx;
+			background-color: #FFFFFF;
+			padding: 30rpx;
+			&-title{
+				font-size: 34rpx;
+			}
+			&-cell{
+				display: flex;
+				padding: 30rpx 0;
+				align-items: center;
+				justify-content: space-between;
+			}
+			&-calendar{
+				position: relative;
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_medical/record.vue b/pages/sub_medical/record.vue
new file mode 100644
index 0000000..3cfa72d
--- /dev/null
+++ b/pages/sub_medical/record.vue
@@ -0,0 +1,102 @@
+<template>
+	<view class="record">
+		<view class="record-item">
+			<view class="record-item-msg">
+				<view class="record-item-msg-left">
+					<u-image src="/static/images/active/mrlfl.png" width="100" mode="widthFix"></u-image>
+				</view>
+				<view class="record-item-msg-center">
+					<view class="record-item-msg-center-item">
+						<text class="record-item-msg-center-item-title">就诊人员:</text>
+						<text class="record-item-msg-center-item-value">李小萌</text>
+					</view>
+					<view class="record-item-msg-center-item">
+						<text class="record-item-msg-center-item-title">就诊医院:</text>
+						<text class="record-item-msg-center-item-value">大理市第二人民医院</text>
+					</view>
+					<view class="record-item-msg-center-item">
+						<text class="record-item-msg-center-item-title">就诊科室:</text>
+						<text class="record-item-msg-center-item-value">普外科</text>
+					</view>
+					<view class="record-item-msg-center-item">
+						<text class="record-item-msg-center-item-title">就诊时间:</text>
+						<text class="record-item-msg-center-item-value">2020-10-27【上午】</text>
+					</view>
+				</view>
+				<view class="record-item-msg-right">
+					<text class="record-item-msg-status">挂号成功</text>
+				</view>
+			</view>
+			<!-- <view class="record-item-btn">
+				<u-button :plain="true" size="mini" type="primary" shape="circle">取消预约</u-button>
+			</view> -->
+		</view>
+	</view>
+</template>
+
+<script>
+	export default{
+		data(){
+			return{
+				
+			}
+		},
+		onLoad(){
+			
+		},
+		methods:{
+			
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	/deep/.u-btn--primary--plain{
+		background-color: #FFFFFF !important;
+	}
+	uni-button{
+		margin-left: 0;
+		margin-right: 0;
+	}
+	.record{
+		font-family: "PingFang-SC-Medium";
+		&-item{
+			background-color: #FFFFFF;
+			margin-bottom: 30rpx;
+			&-msg{
+				padding: 30rpx 10rpx;
+				display: flex;
+				justify-content: space-between;
+				// align-items: center;
+				&-left{
+					flex: 1;
+					display: flex;
+					justify-content: center;
+				}
+				&-center{
+					flex: 3;
+					&-item{
+						padding: 0 0 10rpx;
+						&-title{
+							color: #909399;
+						}
+					}
+				}
+				&-right{
+					display: flex;
+					justify-content: center;
+					flex: 1;
+					color: #3DC64F;
+					&-item{
+						
+					}
+				}
+			}
+			&-btn{
+				padding: 0rpx 30rpx 30rpx;
+				display: flex;
+				justify-content: flex-end;
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_medical/report.vue b/pages/sub_medical/report.vue
new file mode 100644
index 0000000..95a5bd7
--- /dev/null
+++ b/pages/sub_medical/report.vue
@@ -0,0 +1,49 @@
+<template>
+	<view class="report">
+		<view class="report-title">
+			<u-icon name="login" custom-prefix="custom-icon" size="40" color="#666666" label="李小明【3213232423】"></u-icon>
+		</view>
+		<view class="report-item">
+			<u-cell-item title="体测报告" :title-style="tstyle">
+				<u-image slot="icon" src="./images/report.png" width="70" height="70" mode="aspectFit"></u-image>
+			</u-cell-item>
+		</view>
+		<view class="report-item">
+			<u-cell-item title="肝功能报告" :title-style="tstyle">
+				<u-image slot="icon" src="./images/report.png" width="70" height="70" mode="aspectFit"></u-image>
+			</u-cell-item>
+		</view>
+		<view class="report-item">
+			<u-cell-item title="肝功能报告" :title-style="tstyle">
+				<u-image slot="icon" src="./images/report.png" width="70" height="70" mode="aspectFit"></u-image>
+			</u-cell-item>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				tstyle: {
+					marginLeft: '20rpx'
+				}
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.report {
+		font-family: "PingFang-SC-Medium";
+		padding: 10rpx;
+		&-title {
+			margin: 30rpx 10rpx;
+		}
+		&-item{
+			border-radius: 10rpx;
+			margin-bottom: 20rpx;
+			background-color: #FFFFFF;
+		}
+	}
+</style>
diff --git a/pages/sub_medical/reportDetail.vue b/pages/sub_medical/reportDetail.vue
new file mode 100644
index 0000000..9f14cf1
--- /dev/null
+++ b/pages/sub_medical/reportDetail.vue
@@ -0,0 +1,37 @@
+<template>
+	<view class="reportDetail">
+		<view class="reportDetail-title">
+			<text>体测报告</text>
+		</view>
+		<view class="reportDetail-content">
+			<text>体测报告</text>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default{
+		data(){
+			return{
+				
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.reportDetail{
+		font-family: "PingFang-SC-Medium";
+		padding: 30rpx;
+		&-title{
+			display: flex;
+			justify-content: center;
+			font-size: 32rpx;
+			font-weight: bold;
+		}
+		&-content{
+			font-size: 28rpx;
+		}
+	}
+	
+</style>
diff --git a/pages/sub_medical/result.vue b/pages/sub_medical/result.vue
new file mode 100644
index 0000000..a68ab85
--- /dev/null
+++ b/pages/sub_medical/result.vue
@@ -0,0 +1,69 @@
+<template>
+	<view class="result">
+		<view class="result-header">
+			<u-image src="./images//success.png" width="500" height="300"></u-image>
+			<text class="result-header-text">预约成功</text>
+		</view>
+		<view class="result-member">
+			<u-field label="预约信息" placeholder="" disabled  input-align="right" label-width="150"></u-field>
+			<view class="result-member-msg">
+				<u-field label="预约医院" placeholder="大理市第一人民医院(总院)" disabled  :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				<u-field label="预约科室" placeholder="心内科" disabled  :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				<u-field label="预约时间" placeholder="2020-10-26/周一/上午" disabled :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+			</view>
+		</view>
+		<view class="result-member">
+			<u-field label="就诊人信息" placeholder="" disabled  input-align="right" label-width="150"></u-field>
+			<view class="result-member-msg">
+				<u-field label="就诊人员" placeholder="李小明/男/24岁" disabled required :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+				<u-field label="联系方式" placeholder="123****3123" disabled required :placeholder-style="mstyle" input-align="right" :border-bottom="false"></u-field>
+			</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default{
+		data(){
+			return{
+				mstyle:'color:#333333',
+			}
+		},
+		methods:{
+			
+		},
+		onLoad(){
+			
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	
+	.result{
+		font-family: "PingFang-SC-Medium";
+		&-header{
+			background-color: #FFFFFF;
+			display: flex;
+			flex-direction: column;
+			justify-content: center;
+			align-items: center;
+			padding: 30rpx;
+			&-text{
+				margin-top: 30rpx;
+				color: #2FA8E1;
+				font-size: 42rpx;
+			}
+		}
+		&-member{
+			margin-top: 30rpx;
+			background-color: #FFFFFF;
+			&-msg{
+				.u-field{
+					color: #a1a1a1;
+				}
+			}
+			
+		}
+	}
+</style>
diff --git a/pages/sub_medical/z_components/calendar/calendar.vue b/pages/sub_medical/z_components/calendar/calendar.vue
new file mode 100644
index 0000000..98c0113
--- /dev/null
+++ b/pages/sub_medical/z_components/calendar/calendar.vue
@@ -0,0 +1,169 @@
+<template>
+	<view class="calendar">
+		<view class="calendar-weekname">
+			<view class="calendar-weekname-item" v-for="(v,i) in weekname" :key="i">{{v}}</view>
+		</view>
+		<swiper :indicator-dots="true" indicator-color="#CCCCCC" :interval="3000" :duration="1000" indicator-active-color="#2FA8E1"
+		 duration="400" @change="dot_init">
+			<swiper-item>
+				<view class="swiper-item">
+					<view :class="v.isCheck?'swiper-item-item check':'swiper-item-item'" v-for="(v,i) in start_list" :key="i" @click='getDate(start_list,v)'>{{v.day}}</view>
+				</view>
+			</swiper-item>
+			<swiper-item>
+				<view class="swiper-item">
+					<view :class="v.isCheck?'swiper-item-item check':'swiper-item-item'" v-for="(v,i) in next_list" :key="i" @click='getDate(next_list,v)'>{{v.day}}</view>
+				</view>
+			</swiper-item>
+			<swiper-item>
+				<view class="swiper-item">
+					<view :class="v.isCheck?'swiper-item-item check':'swiper-item-item'" v-for="(v,i) in end_list" :key="i" @click='getDate(end_list,v)'>{{v.day}}</view>
+				</view>
+			</swiper-item>
+		</swiper>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				weekname: ['日', '一', '二', '三', '四', '五', '六'],
+				start_list: [],
+				next_list:[],
+				end_list:[]
+			}
+		},
+		methods: {
+			//切换item时
+			dot_init(e){
+				this.start_list.forEach(item0 => {
+					item0.isCheck = false
+				})
+				this.next_list.forEach(item1=>{
+					item1.isCheck = false
+				})
+				this.end_list.forEach(item2=>{
+					item2.isCheck = false
+				})
+				this.start_list[0].isCheck = true
+			},
+			//获取当前信息
+			getDate(list, item) {
+				this.start_list.forEach(item0 => {
+					item0.isCheck = false
+				})
+				this.next_list.forEach(item1=>{
+					item1.isCheck = false
+				})
+				this.end_list.forEach(item2=>{
+					item2.isCheck = false
+				})
+				item.isCheck = true
+				this.$emit('change',item)
+			},
+			//获取日历列表
+			getlist(arr,n) {
+				let date = new Date()
+				let year = date.getFullYear() //当前年份
+				let month = date.getMonth() + 1 //当前月份
+				let total = new Date(year, month, 0).getDate() //当前月份总天数
+				let day = date.getDate() + 7*n //当前天数
+				let list = []
+				this.weekname.forEach((item, index) => {
+					//判断是否超过当前月份总天数 天数是否<10
+					let is_day = day + index <= total ? (day + index >= 10 ? day + index : '0' + (day + index)) : '0' + (day + index -
+						total)
+					let is_day1 = day + index <= total ? day + index : day + index - total
+						//判断是否超过当前月份总天数 月份<10
+					let is_month = day + index <= total ? (month >= 10 ? month : '0' + month) : (month + 1 >= 10 ? month + 1 : '0' +
+							(month + 1))
+					//判断是否超过12月 月份是否<10
+					let is_year = is_month <= 12 ? year : year + 1
+					list.push({
+						day: is_day1,
+						isCheck: index == 0 ? true : false,
+						date: is_year + '' + is_month + '' + is_day
+					})
+				})
+				this[arr] = list
+				//console.log(nowlist)
+			},
+			//获取当天星期列表
+			get_week_list() {
+				let date = new Date()
+				let start_week = date.getDay()
+				let new_start_week = this.numTransfer(start_week)
+				let week_list = this.weekname
+				let splice_week_list = week_list.splice(start_week, week_list.length - start_week)
+				week_list = splice_week_list.concat(week_list)
+				// console.log(week_list)
+				this.weekname = week_list
+			},
+			//数字转中文
+			numTransfer(e) {
+				switch (e) {
+					case 0:
+						return '天'
+					case 1:
+						return '一'
+					case 2:
+						return '二'
+					case 3:
+						return '三'
+					case 4:
+						return '四'
+					case 5:
+						return '五'
+					case 6:
+						return '六'
+				}
+			},
+			//初始化
+			init(){
+				this.get_week_list()
+				this.getlist('start_list',0)
+				this.getlist('next_list',1)
+				this.getlist('end_list',2)
+			}
+		},
+		created() {
+			this.init()
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	uni-swiper {
+		height: 120rpx;
+	}
+
+	.check {
+		background-color: #2FA8E1;
+		color: #FFFFFF;
+	}
+
+	.calendar {
+		touch-action: none;
+		&-weekname {
+			display: flex;
+			justify-content: space-around;
+			margin-bottom: 30rpx;
+		}
+
+		.swiper {
+			&-item {
+				display: flex;
+				justify-content: space-around;
+
+				&-item {
+					width: 50rpx;
+					height: 50rpx;
+					text-align: center;
+					line-height: 50rpx;
+					border-radius: 50%;
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_mine/accountSafe/index.vue b/pages/sub_mine/accountSafe/index.vue
new file mode 100644
index 0000000..add45ed
--- /dev/null
+++ b/pages/sub_mine/accountSafe/index.vue
@@ -0,0 +1,78 @@
+<template>
+	<view class="accountSafe">
+		<view class="accountSafe-list">
+			<u-cell-group :border="false">
+				<u-cell-item :title="v.name" :title-style="titleStyle" :value="i===0?signed:''" @click="i?toPath(v.path):toBind()" v-for="(v,i) in list"
+				 :key="i" :value-style="style">
+				 <u-icon :name="v.icon" custom-prefix="custom-icon" size="40" slot="icon" color="#666666"></u-icon>
+				</u-cell-item>
+			</u-cell-group>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				signed:"未绑定",
+				style:{},
+				titleStyle:{'font-family':'PingFang-SC-Medium','fontSize':'28rpx','marginLeft':'30rpx'},
+				list:[
+					{name:"签约绑卡",icon:"sign",path:"/pages/sub_mine/bindBankCard/index"},
+					{name:"指纹/手势/人脸登录",icon:"login",path:"/pages/sub_mine/otherLogin/index"},
+					{name:"修改登录密码",icon:"phone",path:"/pages/sub_mine/changeLoginPwd/index"},
+					{name:"设置支付密码",icon:"pay",path:"/pages/sub_mine/changePayPwd/index"},
+					{name:"支付(指纹)",icon:"finger",path:"/pages/sub_mine/otherPay/index"},
+					{name:"挂失",icon:"gs",path:"/pages/sub_mine/reportheLoss/index"},
+				]
+			}
+		},
+		onLoad(){
+			
+		},
+		methods: {
+			toBind(){
+				let signed = uni.getStorageSync("signed")
+				let that = this
+				if(signed == "yes"){
+					uni.navigateTo({
+						url:'/pages/sub_mine/unbindBankCard/index'
+					})
+				}else{
+					uni.navigateTo({
+						url:'/pages/sub_mine/bindBankCard/index'
+					})
+				}
+			}
+		},
+		onShow(){
+			let that = this
+			let signed = uni.getStorageSync("signed")
+			//console.log(signed)
+			if(signed == "yes"){
+				that.signed = "已绑定签约"
+			}else if(signed == "no"){
+				that.signed = "已绑定未签约"
+				that.style ={'color':'#DA5961'}
+			}else{
+				that.signed = "未绑定"
+				that.style ={'color':'#DA5961'}
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.accountSafe{
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+		&-list{
+			margin-top: 30rpx;
+		}
+	}
+	
+</style>
diff --git a/pages/sub_mine/agreement/index.vue b/pages/sub_mine/agreement/index.vue
new file mode 100644
index 0000000..dce0c57
--- /dev/null
+++ b/pages/sub_mine/agreement/index.vue
@@ -0,0 +1,76 @@
+<template>
+	<view class="agreement">
+		<view class="agreement-content">
+			<view >
+				本应用尊重并保护所有使用服务用户的个人隐私权。为了给您提供更准确、更有个性化的服务,本应用会按照本隐私权政策的规定使用和披露您的个人信息。但本应用将以高度的勤勉、审慎义务对待这些信息。除本隐私权政策另有规定外,在未征得您事先许可的情况下,本应用不会将这些信息对外披露或向第三方提供。本应用会不时更新本隐私权政策。
+				您在同意本应用服务使用协议之时,即视为您已经同意本隐私权政策全部内容。本隐私权政策属于本应用服务使用协议不可分割的一部分。
+			</view>
+			<view class="big">1. 适用范围</view>
+			<view>(a) 在您注册本应用帐号时,您根据本应用要求提供的个人注册信息;</view>
+			<view>(b) 在您使用本应用网络服务,或访问本应用平台网页时,本应用自动接收并记录的您的浏览器和计算机上的信息,包括但不限于您的IP地址、浏览器的类型、使用的语言、访问日期和时间、软硬件特征信息及您需求的网页记录等数据;</view>
+			<view>(c) 本应用通过合法途径从商业伙伴处取得的用户个人数据。</view>
+			<view>您了解并同意,以下信息不适用本隐私权政策:</view>
+			<view>(a) 您在使用本应用平台提供的搜索服务时输入的关键字信息;</view>
+			<view>(b) 本应用收集到的您在本应用发布的有关信息数据,包括但不限于参与活动、成交信息及评价详情</view>
+			<view>(c) 违反法律规定或违反本应用规则行为及本应用已对您采取的措施。</view>
+			<view class="big">2. 信息使用</view>
+			<view>(a)本应用不会向任何无关第三方提供、出售、出租、分享或交易您的个人信息,除非事先得到您的许可,或该第三方和本应用(含本应用关联公司)单独或共同为您提供服务,且在该服务结束后,其将被禁止访问包括其以前能够访问的所有这些资料。</view>
+			<view>(b) 本应用亦不允许任何第三方以任何手段收集、编辑、出售或者无偿传播您的个人信息。任何本应用平台用户如从事上述活动,一经发现,本应用有权立即终止与该用户的服务协议。</view>
+			<view>(c) 为服务用户的目的,本应用可能通过使用您的个人信息,向您提供您感兴趣的信息,包括但不限于向您发出产品和服务信息,或者与本应用合作伙伴共享信息以便他们向您发送有关其产品和服务的信息(后者需要您的事先同意)。</view>
+			<view class="big">3. 信息披露</view>
+			<view>在如下情况下,本应用将依据您的个人意愿或法律的规定全部或部分的披露您的个人信息</view>
+			<view>(a) 经您事先同意,向第三方披露;</view>
+			<view>(b)为提供您所要求的产品和服务,而必须和第三方分享您的个人信息;</view>
+			<view>(c) 根据法律的有关规定,或者行政或司法机构的要求,向第三方或者行政、司法机构披露;</view>
+			<view>(d) 如您出现违反中国有关法律、法规或者本应用服务协议或相关规则的情况,需要向第三方披露;</view>
+			<view>(e) 如您是适格的知识产权投诉人并已提起投诉,应被投诉人要求,向被投诉人披露,以便双方处理可能的权利纠纷;</view>
+			<view>(f) 在本应用平台上创建的某一交易中,如交易任何一方履行或部分履行了交易义务并提出信息披露请求的,本应用有权决定向该用户提供其交易对方的联络方式等必要信息,以促成交易的完成或纠纷的解决。</view>
+			<view>(g) 其它本应用根据法律、法规或者网站政策认为合适的披露。</view>
+			<view class="big">4. 信息存储和交换</view>
+			<view>本应用收集的有关您的信息和资料将保存在本应用及(或)其关联公司的服务器上,这些信息和资料可能传送至您所在国家、地区或本应用收集信息和资料所在地的境外并在境外被访问、存储和展示。</view>
+			<view class="big">5. Cookie的使用</view>
+			<view>(a) 在您未拒绝接受cookies的情况下,本应用会在您的计算机上设定或取用cookies,以便您能登录或使用依赖于cookies的本应用平台服务或功能。本应用使用cookies可为您提供更加周到的个性化服务,包括推广服务。</view>
+			<view>(b) 您有权选择接受或拒绝接受cookies。您可以通过修改浏览器设置的方式拒绝接受cookies。但如果您选择拒绝接受cookies,则您可能无法登录或使用依赖于cookies的本应用网络服务或功能</view>
+			<view>(c) 通过本应用所设cookies所取得的有关信息,将适用本政策。</view>
+			<view class="big">6. 信息安全</view>
+			<view>(a) 本应用帐号均有安全保护功能,请妥善保管您的用户名及密码信息。本应用将通过对用户密码进行加密等安全措施确保您的信息不丢失,不被滥用和变造。尽管有前述安全措施,但同时也请您注意在信息网络上不存在“完善的安全措施”。</view>
+			<view>(b) 在使用本应用网络服务进行网上交易时,您不可避免的要向交易对方或潜在的交易</view>
+			<view class="big">7.本隐私政策的更改</view>
+			<view>(a)如果决定更改隐私政策,我们会在本政策中、本公司网站中以及我们认为适当的位置发布这些更改,以便您了解我们如何收集、使用您的个人信息,哪些人可以访问这些信息,以及在什么情况下我们会透露这些信息。</view>
+			<view>(b)本公司保留随时修改本政策的权利,因此请经常查看。如对本政策作出重大更改,本公司会通过网站通知的形式告知。</view>
+			<view>方披露自己的个人信息,如联络方式或者邮政地址。请您妥善保护自己的个人信息,仅在必要的情形下向他人提供。如您发现自己的个人信息泄密,尤其是本应用用户名及密码发生泄露,请您立即联络本应用客服,以便本应用采取相应措施。</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				agreement: ""
+			}
+		},
+		methods: {
+			getAgreement() {
+				let that = this
+				that.$u.post("/i/uxy", {}).then((res) => {
+					that.agreement = res.page
+				})
+			}
+		},
+		onLoad() {
+			this.getAgreement()
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.agreement{
+		padding: 30rpx;
+		font-size: 28rpx;
+	}
+	.big{
+		font-size: 36rpx;
+		font-family: "PingFang-SC-Medium";
+	}
+</style>
diff --git a/pages/sub_mine/agreementSign/index.vue b/pages/sub_mine/agreementSign/index.vue
new file mode 100644
index 0000000..2be94e5
--- /dev/null
+++ b/pages/sub_mine/agreementSign/index.vue
@@ -0,0 +1,71 @@
+<template>
+	<view class="agreementSign">
+		<view>本应用尊重并保护所有使用服务用户的个人隐私权。为了给您提供更准确、更有个性化的服务,本应用会按照本隐私权政策的规定使用和披露您的个人信息。但本应用将以高度的勤勉、审慎义务对待这些信息。除本隐私权政策另有规定外,在未征得您事先许可的情况下,本应用不会将这些信息对外披露或向第三方提供。本应用会不时更新本隐私权政策。
+			您在同意本应用服务使用协议之时,即视为您已经同意本隐私权政策全部内容。本隐私权政策属于本应用服务使用协议不可分割的一部分。</view>
+		<view class="title">1. 适用范围</view>
+		<view>(a)在您注册本应用帐号时,您根据本应用要求提供的个人注册信息;</view>
+		<view>(b)在您使用本应用网络服务,或访问本应用平台网页时,本应用自动接收并记录的您的浏览器和计算机上的信息,包括但不限于您的IP地址、浏览器的类型、使用的语言、访问日期和时间、软硬件特征信息及您需求的网页记录等数据;</view>
+		<view>(c)本应用通过合法途径从商业伙伴处取得的用户个人数据。</view>
+		<view class="title">您了解并同意,以下信息不适用本隐私权政策:</view>
+		<view>(a) 您在使用本应用平台提供的搜索服务时输入的关键字信息;</view>
+		<view>(b)本应用收集到的您在本应用发布的有关信息数据,包括但不限于参与活动、成交信息及评价详情;</view>
+		<view>(c) 违反法律规定或违反本应用规则行为及本应用已对您采取的措施。</view>
+		<view class="title">2. 信息使用</view>
+		<view>(a)本应用不会向任何无关第三方提供、出售、出租、分享或交易您的个人信息,除非事先得到您的许可,或该第三方和本应用(含本应用关联公司)单独或共同为您提供服务,且在该服务结束后,其将被禁止访问包括其以前能够访问的所有这些资料。</view>
+		<view>(b)本应用亦不允许任何第三方以任何手段收集、编辑、出售或者无偿传播您的个人信息。任何本应用平台用户如从事上述活动,一经发现,本应用有权立即终止与该用户的服务协议。</view>
+		<view>(c)为服务用户的目的,本应用可能通过使用您的个人信息,向您提供您感兴趣的信息,包括但不限于向您发出产品和服务信息,或者与本应用合作伙伴共享信息以便他们向您发送有关其产品和服务的信息(后者需要您的事先同意)。</view>
+		<view class="title">3.信息披露</view>
+		<view>在如下情况下,本应用将依据您的个人意愿或法律的规定全部或部分的披露您的个人信息:</view>
+		<view>(a) 经您事先同意,向第三方披露;</view>
+		<view>(b)为提供您所要求的产品和服务,而必须和第三方分享您的个人信息;</view>
+		<view>(c)根据法律的有关规定,或者行政或司法机构的要求,向第三方或者行政、司法机构披露;</view>
+		<view>(d) 如您出现违反中国有关法律、法规或者本应用服务协议或相关规则的情况,需要向第三方披露;</view>
+		<view>(e)如您是适格的知识产权投诉人并已提起投诉,应被投诉人要求,向被投诉人披露,以便双方处理可能的权利纠纷;</view>
+		<view>(f)在本应用平台上创建的某一交易中,如交易任何一方履行或部分履行了交易义务并提出信息披露请求的,本应用有权决定向该用户提供其交易对方的联络方式等必要信息,以促成交易的完成或纠纷的解决。</view>
+		<view>(g)其它本应用根据法律、法规或者网站政策认为合适的披露。</view>
+		<view class="title">4. 信息存储和交换</view>
+		<view>本应用收集的有关您的信息和资料将保存在本应用及(或)其关联公司的服务器上,这些信息和资料可能传送至您所在国家、地区或本应用收集信息和资料所在地的境外并在境外被访问、存储和展示。</view>
+		<view class="title">5.Cookie的使用</view>
+		<view>(a)在您未拒绝接受cookies的情况下,本应用会在您的计算机上设定或取用cookies,以便您能登录或使用依赖于cookies的本应用平台服务或功能。本应用使用cookies可为您提供更加周到的个性化服务,包括推广服务。</view>
+		<view>(b)您有权选择接受或拒绝接受cookies。您可以通过修改浏览器设置的方式拒绝接受cookies。但如果您选择拒绝接受cookies,则您可能无法登录或使用依赖于cookies的本应用网络服务或功能。</view>
+		<view>(c)通过本应用所设cookies所取得的有关信息,将适用本政策。</view>
+		<view class="title">6. 信息安全</view>
+		<view>(a)本应用帐号均有安全保护功能,请妥善保管您的用户名及密码信息。本应用将通过对用户密码进行加密等安全措施确保您的信息不丢失,不被滥用和变造。尽管有前述安全措施,但同时也请您注意在信息网络上不存在“完善的安全措施”。</view>
+		<view>(b)在使用本应用网络服务进行网上交易时,您不可避免的要向交易对方或潜在的交易对</view>
+		<view class="title">7.本隐私政策的更改</view>
+		<view>(a)如果决定更改隐私政策,我们会在本政策中、本公司网站中以及我们认为适当的位置发布这些更改,以便您了解我们如何收集、使用您的个人信息,哪些人可以访问这些信息,以及在什么情况下我们会透露这些信息。</view>
+		<view>(b)本公司保留随时修改本政策的权利,因此请经常查看。如对本政策作出重大更改,本公司会通过网站通知的形式告知。</view>
+		<view>方披露自己的个人信息,如联络方式或者邮政地址。请您妥善保护自己的个人信息,仅在必要的情形下向他人提供。如您发现自己的个人信息泄密,尤其是本应用用户名及密码发生泄露,请您立即联络本应用客服,以便本应用采取相应措施。</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				content: ""
+			}
+		},
+		methods: {
+			getBxy() {
+				let that = this
+				that.$u.post("/v1/bxy").then((res) => {
+
+				})
+			}
+		},
+		onLoad() {
+			// this.getBxy()
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.agreementSign{
+		padding: 30rpx;
+		font-size: 28rpx;
+	}
+	.title{
+		font-size: 36rpx;
+	}
+</style>
diff --git a/pages/sub_mine/billsDetails/index.vue b/pages/sub_mine/billsDetails/index.vue
new file mode 100644
index 0000000..8aeb289
--- /dev/null
+++ b/pages/sub_mine/billsDetails/index.vue
@@ -0,0 +1,65 @@
+<template>
+	<view class="billsDetails">
+		<!-- #ifndef MP-WEIXIN -->
+		<u-navbar title="账单详情" :background="background" back-icon-color="#ffffff" title-color="#ffffff" :border-bottom="false"></u-navbar>
+		<!-- #endif -->
+		<view class="billsDetails-desc">
+			<text class="billsDetails-desc-cost">{{msg.amount}}</text>
+			<text class="billsDetails-desc-status">{{msg.status=="success"?'交易成功':'交易失败'}}</text>
+		</view>
+		<view class="billsDetails-list">
+			<u-field v-model="msg.transdesc" :disabled="true" label="交易名称" :field-style="fieldStyle" input-align="right"  clear-size="40"></u-field>
+			<u-field v-model="msg.date" :disabled="true" label="交易时间" :field-style="fieldStyle" input-align="right" clear-size="40"></u-field>
+			<u-field v-model="msg.refno" :disabled="true" label="订单编号" :field-style="fieldStyle" input-align="right" clear-size="40"></u-field>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default{
+		data(){
+			return{
+				msg:{},
+				background:{'backgroundColor':'#03a9f4'},
+				fieldStyle:{'font-size':'30rpx','color':'#999999'}
+			}
+		},
+		onLoad(option){
+			let that = this
+			let data = JSON.parse(option.data) 
+			that.msg = data
+			// let refno = option.refno
+			// let param = {
+			// 	billid:refno
+			// }
+			// that.$u.post("/v1/billdetail",param).then((res)=>{
+				
+			// })
+			
+			// console.log(data)
+		},
+	}
+</script>
+
+<style lang="scss" scoped>
+	.billsDetails{
+		background-color: #FFFFFF;
+		&-desc{
+			background-color: #03a9f4;
+			display: flex;
+			justify-content: center;
+			flex-direction: column;
+			color: #FFFFFF;
+			text-align: center;
+			padding: 50rpx 0;
+			font-family: "PingFang-SC-Medium";
+			&-cost{
+				font-size: 60rpx;
+				margin-bottom: 20rpx;
+			}
+			&-status{
+				font-size: 28rpx;
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_mine/bindBankCard/index.vue b/pages/sub_mine/bindBankCard/index.vue
new file mode 100644
index 0000000..515d7fd
--- /dev/null
+++ b/pages/sub_mine/bindBankCard/index.vue
@@ -0,0 +1,209 @@
+<template>
+	<view class="bindBankCard">
+		<view class="bindBankCard-list">
+			<u-field v-model="name" label="姓名" placeholder="请输入您的真实姓名" placeholder-style="color:#999999;font-family:PingFang-SC-Regular" clear-size="40"></u-field>
+			<u-field @click="showPicker" v-model="cardtype" :disabled="true" label="证件类型" clear-size="40"></u-field>
+			<u-field v-model="idno" label="证件号" placeholder="请输入您的证件号" placeholder-style="color:#999999" clear-size="40"></u-field>
+			<u-field v-model="cardno" label="银行卡号" placeholder="请输入市民卡对应的银行卡号" placeholder-style="color:#999999" clear-size="40"></u-field>
+		</view>
+		<u-button :custom-style="bindBankCardBtn" @click="bindBackCard">下一步</u-button>
+		<u-picker mode="selector" v-model="isShowPicker" :default-selector="[5]" :range="cardtypeList" @confirm="getCard"></u-picker>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				name: "",
+				idno: "",
+				cardno: "",
+				code: "",
+				codeText: "获取验证码",
+				cardtype: "请选择证件类型",
+				cardtypeList: [],
+				isShowPicker: false,
+				checked: false,
+				arr: [],
+				idtype:"",
+				disabled:false,
+				signed:"",
+				bindBankCardBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				}
+			}
+		},
+		computed: {
+
+		},
+		onLoad() {
+			this.getType()
+			let signed = wx.getStorageSync("signed")
+			if(signed=="no"){
+				this.signed = false
+			}else{
+				this.signed = true
+			}
+		},
+		methods: {
+			bindBackCard(){
+				let that =this
+				let {cardno,idtype,name,idno,checked,code} =that
+				if (name == "") {
+					uni.showToast({
+						title: "请填写您的姓名",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				if (idno == "") {
+					uni.showToast({
+						title: "请输入您的证件号",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				if (cardno == "") {
+					uni.showToast({
+						title: "请输入您的市民卡号",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				if (idtype == "") {
+					uni.showToast({
+						title: "请选择您的证件类型",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				if (idtype == "") {
+					uni.showToast({
+						title: "请选择您的证件类型",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				var param = {
+				    "cardno": cardno.trim(),
+				    "idtype": idtype,
+				    "name": name,
+				    "idno": idno.trim()
+				}
+				that.$u.post("/v1/bindcard",param).then((res)=>{
+					uni.setStorageSync("name",name)
+					uni.setStorageSync("cardno", cardno.trim())
+					uni.setStorageSync("idtype", idtype)
+					uni.setStorageSync("idno", idno.trim())
+					uni.setStorageSync("phoneX", res.phonex)
+					uni.setStorageSync("personid", res.personid)
+					uni.setStorageSync("userid", res.personid)
+					uni.setStorageSync("signed", res.signed)
+					uni.setStorageSync("paypwdset", res.paypwdset)
+					uni.showToast({
+						title: "绑定成功",
+						icon: "none",
+						duration: 800,
+						complete(res) {
+							setTimeout(() => {
+								uni.navigateTo({
+									url:"/pages/sub_mine/bindSxy/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			},
+			getType() {
+				let that = this
+				that.$u.post("/v1/idtypes", {}).then((res) => {
+					let arr = []
+					let arr1 =[]
+					for (let i in res.idtypes) {
+						let obj = {
+							name:i,
+							value:res.idtypes[i]
+						}
+						arr.push(obj)
+						arr1.push(res.idtypes[i])
+					}
+					that.cardtypeList = arr1
+					that.cardtype = arr1[5]
+					that.idtype = 'idcard'
+					that.arr = arr
+				})
+			},
+			showPicker() {
+				this.isShowPicker = true
+			},
+			getCard(e) {
+				let that = this
+				that.cardtype = that.cardtypeList[e[0]]
+				that.idtype = that.arr[e[0]].name
+			},
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.bindBankCard {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+		&-toast{
+			display: flex;
+			padding: 20rpx 30rpx;
+			font-family: "PingFang-SC-Medium";
+			font-size: 26rpx;
+			justify-content: space-between;
+			color: #999999;
+		}
+
+		&-list {
+			margin-top: 30rpx;
+			background-color: #FFFFFF;
+		}
+
+		&-lay {
+			font-family: "PingFang-SC-Regular";
+			color: #666666;
+			margin: 10rpx 30rpx;
+
+			&-text {
+				color: #2FA8E1;
+			}
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 30rpx;
+			padding: 50rpx 0;
+		}
+	}
+
+	.btn {
+		color: #2FA8E1;
+		background-color: #FFFFFF;
+		border-color: #2FA8E1;
+		border-width: 1rpx;
+		border-style: solid;
+		font-family: "PingFang-SC-Regular";
+	}
+</style>
diff --git a/pages/sub_mine/bindSxy/index.vue b/pages/sub_mine/bindSxy/index.vue
new file mode 100644
index 0000000..c473f69
--- /dev/null
+++ b/pages/sub_mine/bindSxy/index.vue
@@ -0,0 +1,158 @@
+<template>
+	<view class="bindSxy">
+		<view class="bindSxy-list">
+			<u-field v-model="code" label="短信验证" placeholder="请输入验证码" placeholder-style="color:#999999" clear-size="40">
+				<u-button size="mini" slot="right" type="primary" @click="getCode" shape="circle" class="btn" :disabled="disabled">{{codeText}}</u-button>
+			</u-field>
+		</view>
+		<view class="bindSxy-lay">
+			<u-checkbox v-model="checked" shape="circle" label-size="24">我已同意<text class="bindSxy-lay-text" @click="toPath('/pages/sub_mine/agreementSign/index')">《市民卡免密代扣签约协议》</text></u-checkbox>
+		</view>
+		<u-button :custom-style="bindSxyBtn"  @click="bindSxy">提交</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				code: "",
+				disabled: false,
+				codeText: "获取验证码",
+				checked: false,
+				bindSxyBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				}
+			}
+		},
+		methods: {
+			
+			//获取验证码
+			getCode() {
+				let that = this
+				that.$u.post('/v1/bindcardcode').then(res => {
+					uni.showToast({
+						title: '发送成功',
+						icon: "none",
+						duration: 800
+					})
+					let i = 60
+					that.disabled = true
+					that.timer = setInterval(() => {
+						if (i != 0) {
+							i--
+							that.codeText = i + "s"
+						} else {
+							clearInterval(that.timer)
+							that.codeText = "重新获取"
+							that.disabled = false
+						}
+					}, 1000)
+				})
+			},
+			bindSxy() {
+				let that = this
+				let {
+					code,
+					checked
+				} = that
+				if (code == "") {
+					uni.showToast({
+						title: "请输入验证码",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				if (checked == false) {
+					uni.showToast({
+						title: "请先阅读并同意《市民卡免密代扣签约协议》",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				that.$u.post("/v1/signbxy", {
+					"agree": code
+				}).then((res) => {
+					uni.setStorageSync("signed", "yes")
+					uni.showToast({
+						title: "签约成功",
+						icon: "none",
+						duration: 800,
+						complete(res) {
+							setTimeout(() => {
+								uni.switchTab({
+									url: "/pages/sub_tabbar/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			},
+			
+		},
+		onLoad(){
+			let that = this
+			let i = 60
+			that.disabled = true
+			that.timer = setInterval(() => {
+				if (i != 0) {
+					i--
+					that.codeText = i + "s"
+				} else {
+					clearInterval(that.timer)
+					that.codeText = "重新获取"
+					that.disabled = false
+				}
+			}, 1000)
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.btn {
+		color: #2FA8E1;
+		background-color: #FFFFFF;
+		border-color: #2FA8E1;
+		border-width: 1rpx;
+		border-style: solid;
+		font-family: "PingFang-SC-Regular";
+	}
+	.bindSxy {
+		width: 100vw;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		// background-color: ;
+		&-list {
+			margin-top: 30rpx;
+			background-color: #FFFFFF;
+		}
+		&-lay {
+			font-family: "PingFang-SC-Regular";
+			color: #666666;
+			margin: 10rpx 30rpx;
+		
+			&-text {
+				color: #2FA8E1;
+			}
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 30rpx;
+			padding: 50rpx 0;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/cashFlow/index.vue b/pages/sub_mine/cashFlow/index.vue
new file mode 100644
index 0000000..6a66219
--- /dev/null
+++ b/pages/sub_mine/cashFlow/index.vue
@@ -0,0 +1,349 @@
+<template>
+	<view class="cashFlow">
+		<!-- #ifdef APP-PLUS -->
+		<view class="bgColor"></view>
+		<!-- #endif -->
+		<view class="cashFlow-tabs">
+			<u-icon name="play-left-fill" color="#999999" size="26" @click="topre"></u-icon>
+			<view class="cashFlow-tabs-tabs">
+				<u-tabs :list="list" :current="current" @change="change" bar-width="250" item-width="250" class="cashFlow-tabs-tabs"></u-tabs>
+			</view>
+			<u-icon name="play-right-fill" color="#999999" size="26" @click="tonext"></u-icon>
+		</view>
+		<!-- <v-tabs v-model="current" :tabs="list" @change="change"></v-tabs> -->
+		<view class="cashFlow-content-ucharts">
+			<ring-chart :dataAs="pieData" canvasId="index_ring_1" :titleAs="titleAs" v-if="showPie" />
+		</view>
+		<view class="cashFlow-content">
+			<view class="cashFlow-content-list">
+				<view class="cashFlow-content-list-title">支出明细</view>
+				<scroll-view :scroll-y="true" class="scrollView" @scrolltolower="loadMoreBills" :style="{'height':height+'px'}" v-if="showPie">
+					<view class="cashFlow-content-list-item" v-for="(v,i) in bills" :key="i" @click="toDetails(v)">
+						<view class="cashFlow-content-list-item-content">
+							<text class="cashFlow-content-list-item-content-kind">{{v.transdesc}}</text>
+							<text class="cashFlow-content-list-item-content-date">{{v.date}}</text>
+						</view>
+						<view class="cashFlow-content-list-item-cost">
+							<text>{{v.amount}}</text>
+						</view>
+					</view>
+					<u-loadmore :status="status" :icon-type="iconType" :load-text="loadText" margin-top="30" />
+				</scroll-view>
+			</view>
+		</view>
+
+	</view>
+</template>
+
+<script>
+	import RingChart from '../z_component/stan-ucharts/RingChart.vue';
+	// import vtabs from '@/components/v-tabs/v-tabs.vue';
+	export default {
+		components: {
+			RingChart,
+			// vtabs
+		},
+		data() {
+			return {
+				showPie: false,
+				height: "",
+				status: "loadmore",
+				iconType: 'circle',
+				loadText: {
+					loadmore: '轻轻上拉',
+					loading: '努力加载中',
+					nomore: '暂无更多'
+				},
+				list: [{
+					name: "1月",
+					// ischecked: false
+				}, {
+					name: "2月",
+					// ischecked: false
+				}, {
+					name: "3月",
+					// ischecked: false
+				}, {
+					name: "4月",
+					// ischecked: false
+				}, {
+					name: "5月",
+					// ischecked: false
+				}, {
+					name: "6月",
+					// ischecked: false
+				}, {
+					name: "7月",
+					// ischecked: false
+				}, {
+					name: "8月",
+					// ischecked: false
+				}, {
+					name: "9月",
+					// ischecked: false
+				}, {
+					name: "10月",
+					// ischecked: false
+				}, {
+					name: "11月",
+					// ischecked: false
+				}, {
+					name: "12月",
+					// ischecked: false
+				}],
+				current: new Date().getMonth(),
+				pieData: {
+					//饼状图数据
+					series: []
+				},
+				titleAs: {
+					title: {
+						name: '本卡总支出',
+						fontSize: 16
+					},
+					subtitle: {
+						name: '',
+						fontSize: 12
+					}
+				},
+				bills: [],
+				pageno: 1,
+				end: false,
+				date: "",
+				nullVal: [{
+					name: "总消费",
+					data: 0,
+					legendShape: "rect"
+				}]
+			}
+		},
+		methods: {
+			moveHandle() {
+				return
+			},
+			topre() {
+				let that = this
+				if (that.current != 0) {
+					that.current = that.current - 1
+					let time = new Date().getFullYear() + "" + (that.current + 1 >= 10 ? that.current + 1 : "0" + (that.current + 1))
+					that.date = time
+					that.getbills(1, time)
+					that.getPieVal(time)
+				}
+			},
+			tonext() {
+				let that = this
+				if (that.current != 11) {
+					that.current = that.current + 1
+					let time = new Date().getFullYear() + "" + (that.current + 1 >= 10 ? that.current + 1 : "0" + (that.current + 1))
+					that.date = time
+					that.pageno = 1
+					that.getbills(1, time)
+					that.getPieVal(time)
+				}
+			},
+			change(index) {
+				let that = this
+				that.current = index;
+				let time = new Date().getFullYear() + "" + (that.current + 1 >= 10 ? that.current + 1 : "0" + (that.current + 1))
+				that.date = time
+				that.pageno = 1
+				that.getbills(1, time)
+				that.getPieVal(time)
+			},
+			getbills(no, mon) {
+				let that = this
+				let pageno = no
+				if (pageno == 1) {
+					that.bills = []
+				}
+				let param = {
+					pageno: pageno,
+					month: mon
+				}
+
+				that.$u.post("/v1/bills", param).then((res) => {
+					let list = res.page ? res.page.data : []
+					if (list.length > 0) {
+						list.forEach((item, index) => {
+							let date = item.transdate + item.transtime
+							item.date = item.transdate.substr(0,4) + "-" + item.transdate.substr(4,2)+ "-" + item.transdate.substr(6,2)+ " " + item.transtime.substr(0,2)+ ":" + item.transtime.substr(2,2)+ ":" + item.transtime.substr(4,2);
+						})
+						//console.log(list)
+						that.bills = that.bills.concat(list)
+						that.end = false
+					} else {
+						that.status = "nomore"
+						that.end = true
+					}
+				})
+			},
+			loadMoreBills() {
+				let that = this
+				let pageno = that.pageno++
+				let end = that.end
+				let month = that.date
+				if (!end) {
+					that.getbills(pageno, month)
+				}
+			},
+			toDetails(e) {
+				let data = JSON.stringify(e)
+				uni.navigateTo({
+					url: "/pages/sub_mine/billsDetails/index?data=" + data
+				})
+			},
+			getSrcollViewHeight() {
+				let winHeight
+				let that = this
+				uni.getSystemInfo({
+					success: function(res) {
+						winHeight = res.windowHeight
+					}
+				});
+				//console.log(winHeight)
+				const query = uni.createSelectorQuery().in(that);
+				query.select('.cashFlow-content-list-title').boundingClientRect(data => {
+					console.log(data)
+					if(!data){
+						setTimeout(()=>{
+							that.getSrcollViewHeight()
+						},10)
+						return
+					}
+					that.height = winHeight - data.top - data.height - 15
+					// that.height = (data.bottom - data.height)*2
+				}).exec();
+			},
+			getPieVal(mon) {
+				let that = this
+				that.showPie = false
+				let param = {
+					month: mon
+				}
+				that.$u.post("/v1/billcount", param).then(res => {
+					let total = res.data ? res.data.total : null
+					//console.log(total)
+					that.titleAs.subtitle.name = "¥" + Math.abs(total)
+					if (total === 0 || !total) {
+						that.pieData.series = that.nullVal
+						that.showPie = true
+						return false
+					}
+					let list = res.data.group
+					let newList = []
+					list.map((value, index, arry) => {
+						newList.push({
+							"name": value.transtype,
+							"data": Math.abs(value.amount),
+							"legendShape": "rect"
+						})
+					})
+					that.pieData.series = newList
+					that.showPie = true
+				})
+			}
+		},
+		onLoad() {
+			let that = this
+			let mon = new Date().getFullYear() + "" + (new Date().getMonth() + 1 > 10 ? new Date().getMonth() + 1 : '0' + (new Date()
+				.getMonth() + 1))
+			//console.log(mon)
+			that.date = mon
+			that.getbills(1, mon)
+			that.getPieVal(mon)
+			this.getSrcollViewHeight()
+		},
+	}
+</script>
+
+<style scoped lang="scss">
+	.scrollView {
+		// height: calc(100vh - 710rpx)
+	}
+	.cashFlow-content-ucharts{
+		height: 250px;
+	}
+
+	scroll-view ::-webkit-scrollbar {
+		width: 0;
+		height: 0;
+		display: none;
+		background-color: transparent;
+	}
+	/* #ifdef APP-PLUS */
+	.bgColor {
+		position: fixed;
+		top: 0;
+		left: 0;
+		right: 0;
+		bottom: 0;
+		background: #FFFFFF;
+		z-index: -1;
+	}
+	/* #endif */
+	
+
+	page {
+		background-color: #FFFFFF;
+	}
+
+	.cashFlow {
+		background-color: #FFFFFF;
+		&-tabs {
+			display: flex;
+			// height: 500rpx;
+			justify-content: space-around;
+			padding: 10rpx 30rpx 0;
+
+			&-tabs {
+				width: 95%;
+			}
+		}
+
+		&-content {
+
+			&-list {
+				padding: 30rpx;
+
+				&-title {
+					font-family: "PingFang-SC-Medium";
+					color: #343434;
+					font-size: 32rpx;
+				}
+
+				&-item {
+					display: flex;
+					justify-content: space-between;
+					align-items: center;
+					border-bottom: 1rpx solid #CCCCCC;
+					padding: 30rpx 0;
+
+					&-content {
+						display: flex;
+						flex-direction: column;
+
+						&-kind {
+							color: #343434;
+							font-size: 30rpx;
+							font-family: "PingFang-SC-Medium";
+							margin-bottom: 10rpx;
+						}
+
+						&-date {
+							color: #9A9A9A;
+							font-size: 26rpx;
+							font-family: "PingFang-SC-Medium";
+						}
+					}
+
+					&-cost {
+						color: #666666;
+						font-size: 32rpx;
+						font-family: "PingFang-SC-Medium";
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_mine/changeLoginPwd/index.vue b/pages/sub_mine/changeLoginPwd/index.vue
new file mode 100644
index 0000000..7828d2b
--- /dev/null
+++ b/pages/sub_mine/changeLoginPwd/index.vue
@@ -0,0 +1,114 @@
+<template>
+	<view class="changeLoginPwd">
+		<view class="changeLoginPwd-list">
+			<u-field v-model="oldpwd" label="原登陆密码" :field-style="fieldStyle" placeholder="请输入登陆密码"
+			 label-width="160" maxlength="12" :password="true" clear-size="40"></u-field>
+			<u-field v-model="newpwd" label="新登陆密码" :field-style="fieldStyle" placeholder="请设置6-12位密码"
+			 label-width="160" maxlength="12" :password="true" clear-size="40"></u-field>
+			<u-field v-model="renewpwd" label="确认密码" :field-style="fieldStyle" placeholder="请确认新密码"
+			 label-width="160" maxlength="12" :password="true" clear-size="40"></u-field>
+		</view>
+		<u-button  @click="changeLoginPwd" :custom-style="changeLoginPwdBtn">确认修改</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				oldpwd: "",
+				newpwd: "",
+				renewpwd: "",
+				fieldStyle:{'font-size':'30rpx','color':'#999999'},
+				changeLoginPwdBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				}
+			}
+		},
+		methods: {
+			changeLoginPwd() {
+				let that = this
+				let {
+					newpwd,
+					renewpwd,
+					oldpwd
+				} = that
+				if (oldpwd == "") {
+					uni.showToast({
+						title: "请输入原登录密码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (newpwd.length < 6) {
+					uni.showToast({
+						title: "新密码必须6位以上字符",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (newpwd != renewpwd) {
+					uni.showToast({
+						title: "两次密码不一致,请确认后重新输入",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				let param = {
+					"newpwd": newpwd,
+					"renewpwd": renewpwd,
+					"oldpwd": oldpwd
+				}
+				that.$u.post("/v1/pwdset", param).then((res) => {
+					uni.showToast({
+						title: "密码修改成功",
+						icon: "none",
+						duration: 800,
+						complete(res) {
+							setTimeout(() => {
+								uni.switchTab({
+									url: "/pages/sub_tabbar/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			}
+
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.changeLoginPwd {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		&-list {
+			background-color: #FFFFFF;
+			margin-top: 30rpx;
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 100rpx;
+			padding: 50rpx 0;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/changePayPwd/index.vue b/pages/sub_mine/changePayPwd/index.vue
new file mode 100644
index 0000000..5fda242
--- /dev/null
+++ b/pages/sub_mine/changePayPwd/index.vue
@@ -0,0 +1,127 @@
+<template>
+	<view class="changePayPwd">
+		<view class="changePayPwd-list">
+			<u-field v-model="pwd" label="支付密码" :field-style="fieldStyle" placeholder="请设置6-12位密码"
+			 label-width="160" :password="true" maxlength="12" clear-size="40"></u-field>
+			<u-field v-model="repwd" label="确认密码" :field-style="fieldStyle" placeholder="请确认新密码"
+			 label-width="160" :password="true" maxlength="12" clear-size="40"></u-field>
+		</view>
+		<view class="changePayPwd-forget">
+			<text @click="toForgetPwd">忘记密码?</text>
+		</view>
+		<u-button @click="changePayPwd" :custom-style="changePayPwdBtn">确认修改</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				pwd: "",
+				repwd: "",
+				fieldStyle:{'font-size':'30rpx','color':'#999999'},
+				changePayPwdBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				}
+			}
+		},
+		methods: {
+			toForgetPwd() {
+				uni.navigateTo({
+					url: "/pages/sub_mine/findPayPwd/index"
+				})
+			},
+			changePayPwd() {
+				let that = this
+				let {
+					pwd,
+					repwd
+				} = that
+				if (pwd == "") {
+					uni.showToast({
+						title: "请输入支付密码",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				if (repwd != pwd) {
+					uni.showToast({
+						title: "两次支付密码不一致,请确认后重新输入",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				let paypwdtype = uni.getStorageSync("paypwdtype");
+				if (paypwdtype == "") {
+					paypwdtype = "new"
+				}
+				var randomcode = uni.getStorageSync("randomcode");
+				if (randomcode == "") {
+					randomcode = ""
+				}
+				let param = {
+					"pwd": pwd,
+					"repwd": repwd,
+					"type": paypwdtype,
+					"randcode": randomcode
+				}
+				that.$u.post("/v1/paypwd", param).then((res) => {
+					uni.showToast({
+						title: "设置支付密码成功",
+						icon: "none",
+						duration: 800,
+						complete(res) {
+							setTimeout(() => {
+								uni.switchTab({
+									url: "/pages/sub_tabbar/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			}
+		},
+	}
+</script>
+
+<style lang="scss" scoped>
+	.changePayPwd {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		&-list {
+			background-color: #FFFFFF;
+			margin-top: 30rpx;
+		}
+
+		&-forget {
+			font-size: 24rpx;
+			font-family: "PingFang-SC-Regular";
+			display: flex;
+			padding: 30rpx 30rpx 0;
+			color: #666666;
+			justify-content: flex-end;
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 50rpx;
+			padding: 50rpx 0;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/findPayPwd/index.vue b/pages/sub_mine/findPayPwd/index.vue
new file mode 100644
index 0000000..81283d1
--- /dev/null
+++ b/pages/sub_mine/findPayPwd/index.vue
@@ -0,0 +1,184 @@
+<template>
+	<view class="findPayPwd">
+		<view class="findPayPwd-list">
+			<u-field v-model="tel" label="手机号" placeholder="请输入手机号" placeholder-style="color:#999999;font-family:PingFang-SC-Regular"
+			 label-width="160" maxlength="11" type="number" clear-size="40"></u-field>
+			<u-field v-model="code" label="验证码" placeholder="请输入验证码" clear-size="40" placeholder-style="color:#999999" label-width="160" maxlength="6" type="number">
+				<u-button size="mini" slot="right" type="primary" @click="getCode" shape="circle" :custom-style="btn" :disabled="isChecked">{{codeText}}</u-button>
+			</u-field>
+			<u-field v-model="pwd" label="新密码" placeholder="请输入6位密码" clear-size="40" placeholder-style="color:#999999" label-width="160" maxlength="6" :password="true" type="number"></u-field>
+			<u-field v-model="repwd" label="确认新密码" placeholder="请确认密码" clear-size="40" placeholder-style="color:#999999" label-width="160" maxlength="6" :password="true" type="number"></u-field>
+		</view>
+		<u-button class="findPayPwd-btn" @click="findPayPwd" :custom-style="findPayPwdBtn">确认</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				codeText: "获取验证码",
+				tel: "",
+				code: "",
+				pwd: "",
+				repwd: "",
+				isChecked:false,
+				btn:{
+					color: '#2FA8E1',
+					backgroundColor: '#FFFFFF',
+					borderColor:'#2FA8E1',
+					borderWidth: '1rpx',
+					borderStyle: 'solid',
+					fontFamily: "PingFang-SC-Regular"
+				},
+				findPayPwdBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				}
+			}
+		},
+		methods: {
+			getCode() {
+				let that = this
+				let tel = that.tel
+				if (tel == "") {
+					uni.showToast({
+						title: "请输入正确手机号",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				that.$u.post('/v1/code', {}).then(res => {
+					uni.showToast({
+						title: res.msg,
+						icon: "none",
+						duration: 800
+					})
+					let i = 60
+					that.isChecked = true
+					that.timer = setInterval(() => {
+						if (i != 0) {
+							i--
+							that.codeText = i + "s"
+						} else {
+							clearInterval(that.timer)
+							that.codeText = "重新获取"
+							that.isChecked = false
+						}
+					}, 1000)
+				})
+			},
+			async findPayPwd() {
+				let that = this
+				let {
+					tel,
+					pwd,
+					code,
+					repwd
+				} = that
+				if (tel == "") {
+					uni.showToast({
+						title: "请输入正确手机号",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (code == "") {
+					uni.showToast({
+						title: "请输入验证码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (pwd == "") {
+					uni.showToast({
+						title: "请设置您的密码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				if (pwd != repwd) {
+					uni.showToast({
+						title: "二次输入密码不一致,请确认后重新输入",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				let param = {
+					code: code,
+				}
+				let ret = await that.$u.post("/v1/checkcode", param)
+				if (ret.code === 200) {
+					let {
+						randcode
+					} = ret
+					let param = {
+						"pwd": pwd,
+						"repwd": repwd,
+						"type": "find",
+						"randcode": randcode
+					}
+					that.$u.post("/v1/paypwd", param).then((res) => {
+						uni.showToast({
+							title: "密码重置成功",
+							icon: "none",
+							duration: 800,
+							complete(res){
+								setTimeout(() => {
+									uni.reLaunch({
+										url: "/pages/sub_tabbar/index"
+									})
+								}, 1500)
+							}
+						})
+					})
+				}
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.findPayPwd {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		&-list {
+			margin-top: 30rpx;
+			background-color: #FFFFFF;
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 100rpx;
+			padding: 50rpx 0;
+		}
+
+	}
+
+	.btn {
+		color: #2FA8E1;
+		background-color: #FFFFFF;
+		border-color: #2FA8E1;
+		border-width: 1rpx;
+		border-style: solid;
+		font-family: "PingFang-SC-Regular";
+	}
+</style>
diff --git a/pages/sub_mine/integral/index.vue b/pages/sub_mine/integral/index.vue
new file mode 100644
index 0000000..9047c76
--- /dev/null
+++ b/pages/sub_mine/integral/index.vue
@@ -0,0 +1,315 @@
+<template>
+	<view class="integral">
+		<view class="integral-bannar">
+			<view class="integral-bannar-left">
+				<text>您当前共有</text>
+				<text class="integral-bannar-left-num"><text class="big">{{value}}</text>积分</text>
+			</view>
+			<view class="integral-bannar-btn" @click="toPath('/pages/sub_mine/integralQuery/index')">
+				积分查询
+			</view>
+		</view>
+		<view class="integral-item" v-for="(v,i) in list" :key="i">
+			<view class="integral-item-title">
+				<view class="integral-item-title-box"></view>
+				<text>{{v.name}}</text>
+			</view>
+			<view class="integral-item-integral" v-if="v.name =='积分任务'">
+				<view class="integral-item-integral-item" v-for="(item,index) in v.list" :key="index">
+					<view class="integral-item-integral-item-left">
+						<u-image :src="item.imgSrc" width="80rpx" mode="widthFix"></u-image>
+						<view class="integral-item-integral-item-left-desc">
+							<text class="integral-item-integral-item-left-desc-name">{{item.taskname?item.taskname:errList[index].taskname}}</text>
+							<text class="integral-item-integral-item-left-desc-desc">{{item.desc?item.desc:'暂无'}}</text>
+						</view>
+					</view>
+					<view :class=" item.isFinish?'integral-item-integral-item-btnc':'integral-item-integral-item-btn'" @click="item.isFinish?'':getIntegral(item)">{{item.transtatus?item.transtatus:'未完成'}}</view>
+				</view>
+			</view>
+		</view>
+		<view class="integral-toast">
+			<view class="integral-toast-title">活动规则:</view>
+			<view>1.积分使用期限为1年,若1年内未兑换,将自动清空</view>
+			<view>2.积分不得转让或买卖</view>
+			<view>3.请正确合理使用积分</view>
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				list: [{
+					name: "积分任务",
+					list: [{
+							imgSrc: "/static/images/active/mrlfl.png",
+							isFinish: false
+						},
+						{
+							imgSrc: "/static/images/active/sfrzhb.png",
+							isFinish: false
+						}, {
+							imgSrc: "/static/images/active/scxfhb.png",
+							isFinish: false
+						},
+						{
+							imgSrc: "/static/images/active/scdhjf.png",
+							isFinish: false
+						},
+					]
+				}],
+				value: 0,
+				errList: [{
+						imgSrc: "/static/images/active/mrlfl.png",
+						isFinish: false,
+						taskname: "每日签到"
+					},
+					{
+						imgSrc: "/static/images/active/sfrzhb.png",
+						isFinish: false,
+						taskname: "身份认证"
+					}, {
+						imgSrc: "/static/images/active/scxfhb.png",
+						isFinish: false,
+						taskname: "首次消费"
+					},
+					{
+						imgSrc: "/static/images/active/scdhjf.png",
+						isFinish: false,
+						taskname: "首次兑换积分"
+					},
+				]
+			}
+		},
+		methods: {
+			getIntegralStatus() {
+				let that = this
+				that.$u.get('v1/point/taskstatus', {}).then(res => {
+					let list = that.list[0].list
+					let reslist = res.data
+					//undone 未做   done未领取  received 已领取
+					list = list.map((item, index) => {
+						reslist[index].desc = '可获得' + reslist[index].points + '积分'
+						if (reslist[index].status == 'done') {
+							reslist[index].transtatus = index ? '领取' : '已签到'
+							item.isFinish = index ? false : true
+						} else if (reslist[index].status == 'undone') {
+							reslist[index].transtatus = index ? '去完成' : '签到'
+							item.isFinish = false
+						} else if (reslist[index].status == 'received') {
+							reslist[index].transtatus = index ? '已领取' : '已签到'
+							item.isFinish = true
+						}
+						return { ...item,
+							...reslist[index]
+						}
+					})
+
+					that.list[0].list = list
+					//console.log(list)
+				})
+			},
+			getIntegral(item) {
+				let that = this
+				if(item.status == 'undone' && item.taskcode  != 'signin'){
+					uni.showToast({
+						icon: "none",
+						title: "此任务暂时无法完成",
+						duration: 1500
+					})
+					return
+				}
+				// console.log(item.taskcode)
+				if (item.taskcode == 'signin') {
+					that.$u.post('v1/point/task/' + item.taskcode, {}).then(res => {
+						uni.showToast({
+							icon: "none",
+							title: "签到成功",
+							duration: 1500
+						})
+						that.getIntegralStatus()
+						that.getIntegralTotals()
+					})
+				} else if (item.taskcode == 'auth' || item.taskcode == 'consume') {
+					that.$u.post('v1/point/task/' + item.taskcode, {}).then(res => {
+						uni.showToast({
+							icon: "none",
+							title: "领取成功",
+							duration: 1500
+						})
+						that.getIntegralStatus()
+						that.getIntegralTotals()
+					})
+				} else {
+					uni.showToast({
+						icon: "none",
+						title: "此积分任务暂未开放",
+						duration: 1500
+					})
+				}
+			},
+			getIntegralTotals() {
+				let that = this
+				that.$u.get("/v1/point/total", {}).then(res => {
+					that.value = res.data
+				})
+			}
+
+		},
+		onLoad() {
+			let that = this
+			that.getIntegralStatus()
+			that.getIntegralTotals()
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.integral {
+		width: 100vw;
+		height: 100vh;
+		background-color: #FFFFFF;
+		padding: 20rpx;
+		font-family: "PingFang-SC-Medium";
+
+		&-bannar {
+			background-image: url(/static/images/integral/bannar.png);
+			background-position: top;
+			background-repeat: no-repeat;
+			background-size: cover;
+			display: flex;
+			justify-content: space-between;
+			padding: 80rpx 30rpx;
+			color: #FFFFFF;
+			border-radius: 20rpx;
+			align-items: center;
+
+			&-left {
+				display: flex;
+				flex-direction: column;
+				font-size: 28rpx;
+				margin-left: 30rpx;
+
+				&-num {
+					.big {
+						font-family: "DIN-Bold";
+						font-size: 64rpx;
+						font-weight: bold;
+						margin-right: 10rpx;
+					}
+				}
+			}
+
+			&-btn {
+				// margin-top: 50rpx;
+				background-color: #73C5EB;
+				border-radius: 50rpx;
+				// padding: 30rpx 50rpx;
+				width: 170rpx;
+				height: 60rpx;
+				font-size: 28rpx;
+				display: flex;
+				justify-content: center;
+				align-items: center;
+			}
+		}
+
+		&-item {
+			display: flex;
+			flex-direction: column;
+			margin: 30rpx 0;
+
+			&-title {
+				display: flex;
+				align-items: center;
+				margin-bottom: 30rpx;
+
+				&-box {
+					width: 6rpx;
+					height: 30rpx;
+					background-image: linear-gradient(#7DD2F9, #30A8E1);
+					margin-right: 20rpx;
+				}
+
+				text {
+					font-size: 32rpx;
+					color: #343434;
+				}
+			}
+
+			&-integral {
+				&-item {
+					display: flex;
+					justify-content: space-between;
+					align-items: center;
+					margin-bottom: 30rpx;
+
+					&-left {
+						display: flex;
+						align-items: center;
+
+						&-desc {
+							display: flex;
+							// align-items: center;
+							flex-direction: column;
+							margin-left: 10rpx;
+
+							&-name {
+								color: #343434;
+								font-size: 32rpx;
+							}
+
+							&-desc {
+								color: #9A9A9A;
+								font-size: 25rpx;
+							}
+						}
+					}
+
+					&-btn {
+						background-color: #30A8E1;
+						color: #FFFFFF;
+						border-radius: 50rpx;
+						padding: 10rpx 30rpx;
+						font-family: "PingFang-SC-Regular";
+						font-size: 28rpx;
+						width: 150rpx;
+						text-align: center;
+					}
+
+					&-btnc {
+						background-color: #63CEFF;
+						color: #FFFFFF;
+						border-radius: 50rpx;
+						padding: 10rpx 30rpx;
+						font-family: "PingFang-SC-Regular";
+						font-size: 28rpx;
+						width: 150rpx;
+						text-align: center;
+					}
+				}
+			}
+		}
+
+		&-toast {
+			color: #656565;
+
+			view {
+				margin-bottom: 10rpx;
+			}
+
+			&-title {
+				color: #333333;
+				font-size: 28rpx;
+			}
+		}
+	}
+
+	/* #ifdef MP-WEIXIN */
+	.integral-bannar {
+		background-image: url();
+	}
+
+	/* #endif */
+</style>
diff --git a/pages/sub_mine/integralQuery/index.vue b/pages/sub_mine/integralQuery/index.vue
new file mode 100644
index 0000000..bf48b67
--- /dev/null
+++ b/pages/sub_mine/integralQuery/index.vue
@@ -0,0 +1,133 @@
+<template>
+	<view class="integralQuery">
+		<!-- #ifndef H5 -->
+		<view class="bgColor"></view>
+		<!-- #endif -->
+		<view class="integralQuery-item" v-for="(v,i) in list" :key="i">
+			<view class="integralQuery-item-left">
+				<text class="integralQuery-item-left-name">{{v.typename}}</text>
+				<text class="integralQuery-item-left-date">{{v.date}}</text>
+			</view>
+			<view class="integralQuery-item-right" :style="{color:v.pointStatus=='add'?'#2FA7E0':'#F95A3D'}">
+				{{v.points}}
+			</view>
+		</view>
+		<u-loadmore :status="status" :icon-type="iconType" :load-text="loadText" margin-top="30" />
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				isAdd: false,
+				list: [],
+				pageno: 1,
+				status: "loading",
+				iconType: 'circle',
+				loadText: {
+					loadmore: '轻轻上拉',
+					loading: '努力加载中',
+					nomore: '暂无更多'
+				},
+			}
+		},
+		methods: {
+			getIntegralList(e) {
+				let that = this
+				let params = {
+					pageno: e,
+					pagesize: 10
+				}
+				that.pageno = e
+				that.$u.get("/v1/point/flow", params).then(res => {
+					let totals = res.data.count
+					let list = res.data.data
+					if (list.length > 0) {
+						list.forEach(item => {
+							item.date = item.transdate.substr(0, 4) + '-' + item.transdate.substr(4, 2) + '-' + item.transdate.substr(6,
+								2) + ' ' + item.transtime.substr(0, 2) + ':' + item.transtime.substr(2, 2) + ':' + item.transtime.substr(4,
+								2)
+							item.pointStatus = item.points.indexOf("+") != -1 ? 'add' : 'mins'
+						})
+						that.list = that.list.concat(list)
+						that.status = 'loadmore'
+						//console.log(that.list)
+					} else {
+						that.status = 'nomore'
+					}
+				}).catch(res=>{
+					that.status = 'nomore'
+				})
+			}
+		},
+		onLoad() {
+			let that = this
+			that.getIntegralList(1)
+		},
+		onReachBottom() {
+			let that = this
+			let pageno = ++that.pageno
+			let status = that.status
+			if (status != 'nomore') {
+				that.getIntegralList(pageno)
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	/* #ifndef H5 */
+	.bgColor {
+		position: fixed;
+		top: 0;
+		left: 0;
+		right: 0;
+		bottom: 0;
+		background: #FFFFFF;
+		z-index: -1;
+	}
+	/* #endif */
+	page{
+		background-color: #FFFFFF;
+	}
+	.integralQuery {
+		padding: 20rpx 30rpx;
+		background-color: #FFFFFF;
+		width: 100vw;
+		// height: 100vh;
+		font-family: "PingFang-SC-Medium";
+
+		&-item {
+			display: flex;
+			justify-content: space-between;
+			align-items: center;
+			border-bottom: 2rpx rgba(203, 203, 203, 1) solid;
+			padding: 20rpx 0;
+
+			&-left {
+				display: flex;
+				flex-direction: column;
+
+				text {
+					margin: 5rpx;
+				}
+
+				&-name {
+					font-size: 31rpx;
+					color: #333333;
+				}
+
+				&-date {
+					color: #999999;
+					font-size: 25rpx;
+				}
+			}
+
+			&-right {
+				font-size: 32rpx;
+				// color: #2FA7E0;
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_mine/leaveMsg/index.vue b/pages/sub_mine/leaveMsg/index.vue
new file mode 100644
index 0000000..18cab56
--- /dev/null
+++ b/pages/sub_mine/leaveMsg/index.vue
@@ -0,0 +1,121 @@
+<template>
+	<view class="leaveMsg">
+		<view class="leaveMsg-con">
+			<u-input v-model="title" placeholder="请填写留言标题(14字符之内)" maxlength="14" />
+			<u-input v-model="value" type="textarea" :border="false" height="300" :auto-height="true" placeholder="请填写您的留言内容(140字符之内)"
+			 maxlength="140" />
+			<u-upload :action="action" ref="uUpload" :max-size="2 * 1024 * 1024" max-count="4" @on-change="get" @on-remove="remove"
+			 :header="header"></u-upload>
+		</view>
+		<u-button @click="submit" :custom-style="leaveMsgnBtn">提交留言</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				title: "",
+				value: "",
+				action: "",
+				header: {
+					Authorization: ""
+				},
+				leaveMsgnBtn: {
+					backgroundColor: ' #2FA8E1',
+					padding: '50rpx 0',
+					color: '#FFFFFF',
+					width: ' 600rpx',
+					fontSize: '30rpx',
+					border: '1px solid #2FA8E1',
+					marginTop: '50rpx'
+				},
+				list: []
+			}
+		},
+		methods: {
+			get(res, index, lists) {
+				let that = this
+				let obj = {
+					minpicid: JSON.parse(res.data).minpicid,
+					picid: JSON.parse(res.data).picid
+				}
+				that.list.push(obj)
+			},
+			submit() {
+				let that = this
+				let {
+					title,
+					value,
+					list
+				} = that
+				if (title == "") {
+					uni.showToast({
+						icon: "none",
+						title: "请填写留言标题",
+						duration: 1500
+					})
+					return false
+				}
+				if (value == "") {
+					uni.showToast({
+						icon: "none",
+						title: "请填写留言内容",
+						duration: 1500
+					})
+					return false
+				}
+				let params = {
+					title: title,
+					content: value,
+					pictures: list
+				}
+				that.$u.post("/v1/feedback/release", params).then(res => {
+					uni.showToast({
+						title: "留言成功,我们将尽快给您回复",
+						icon:"none",
+						duration:1500,
+						complete: (res) => {
+							setTimeout(() => {
+								uni.navigateBack({
+									delta:1
+								})
+							}, 1500)
+						}
+					})
+				})
+			},
+			remove(index, lists) {
+				let that = this
+				that.list.splice(index, 1)
+			}
+		},
+		onLoad() {
+			let that = this
+			let token = uni.getStorageSync("token")
+			that.action = that.$u.http.config.baseUrl + "/v1/uploadpic"
+			that.header.Authorization = "Bearer " + token
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.leaveMsg {
+		width: 100vw;
+		height: 100vh;
+		background-color: #FFFFFF;
+
+		&-btn {
+			background-color: #2FA8E1;
+			font-family: "PingFang-SC-Medium";
+			color: #FFFFFF;
+			border-radius: 50rpx;
+			padding: 20rpx 30rpx;
+			font-size: 30rpx;
+		}
+
+		&-con {
+			padding: 10rpx 30rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/leaveMsgDetail/index.vue b/pages/sub_mine/leaveMsgDetail/index.vue
new file mode 100644
index 0000000..58bf971
--- /dev/null
+++ b/pages/sub_mine/leaveMsgDetail/index.vue
@@ -0,0 +1,177 @@
+<template>
+	<view class="leaveMsgDetail">
+		<view class="leaveMsgDetail-header">
+			<view class="leaveMsgDetail-header-title">
+				{{leaveMsgDate.title}}
+			</view>
+			<view class="leaveMsgDetail-header-avatar">
+				<u-avatar :src="avatar" size="110"></u-avatar>
+				<view class="leaveMsgDetail-header-avatar-desc">
+					<text class="leaveMsgDetail-header-avatar-desc-name">{{name}}</text>
+					<text class="leaveMsgDetail-header-avatar-desc-date">{{leaveMsgDate.fbtime}}</text>
+				</view>
+			</view>
+			<view class="leaveMsgDetail-header-con">
+				{{leaveMsgDate.content}}
+			</view>
+		</view>
+		<view class="leaveMsgDetail-line"></view>
+		<view class="leaveMsgDetail-items"  v-if="leaveMsgDate.replystatus == '1'">
+			<view class="leaveMsgDetail-items-desc">
+				<view class="leaveMsgDetail-items-desc-left">
+					<u-avatar src="/static/images/login/logo.png" size="112"></u-avatar>
+				</view>
+				<view class="leaveMsgDetail-items-desc-right">
+					<view class="leaveMsgDetail-items-desc-right-author">
+						<text class="leaveMsgDetail-items-desc-right-author-name">大理市民卡</text>
+					</view>
+					<view class="leaveMsgDetail-items-desc-right-date">{{leaveMsgDate.reply.updatetime}}</view>
+					<view class="leaveMsgDetail-items-desc-right-desc">{{leaveMsgDate.reply.replycontent}}</view>
+				</view>
+			</view>
+		</view>
+		<view class="leaveMsgDetail-answer" v-if="leaveMsgDate.replystatus == '0'">暂无回复</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				leaveMsgDate:{},
+				name:"",
+				avatar:""
+				
+			}
+		},
+		onLoad(option) {
+			let that = this
+			that.getDetail(option.id)
+			that.name = uni.getStorageSync("name")?uni.getStorageSync("name"):"用户"
+		},
+		methods:{
+			getDetail(e){
+				let that = this 
+				that.$u.get('/v1/feedback/'+e).then(res=>{
+					let item = res.data
+					item.fbtime = item.fbtime.substr(0,4) + "-" + item.fbtime.substr(4,2)+ "-" + item.fbtime.substr(6,2)+ " " + item.fbtime.substr(8,2)+ ":" + item.fbtime.substr(10,2)+ ":" + item.fbtime.substr(12,2);
+					let reply = item.reply
+					if(reply){
+						let time = item.reply.updatetime
+						time = time.substr(0,4) + "-" + time.substr(4,2)+ "-" + time.substr(6,2)+ " " + time.substr(8,2)+ ":" + time.substr(10,2)+ ":" + time.substr(12,2);
+						item.reply.updatetime = time
+					}
+					that.leaveMsgDate = item
+				})
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.leaveMsgDetail {
+		width: 100vw;
+		height: 100vh;
+		background-color: #FFFFFF;
+		font-family: "PingFang-SC-Medium";
+		&-answer{
+			display: flex;
+			justify-content: center;
+			font-size: 40rpx;
+			font-weight: bold;
+			margin-top: 100rpx;
+		}
+
+		&-header {
+			padding: 30rpx;
+
+			&-title {
+				color: #343434;
+				font-size: 31rpx;
+			}
+
+			&-avatar {
+				display: flex;
+				margin: 30rpx 0 20rpx;
+
+				&-desc {
+					display: flex;
+					flex-direction: column;
+					justify-content: space-around;
+					margin-left: 20rpx;
+
+					&-name {
+						color: #343434;
+						font-size: 28rpx;
+					}
+
+					&-date {
+						color: #9A9A9A;
+						font-size: 24rpx;
+					}
+				}
+			}
+
+			&-con {
+				color: #666666;
+				font-size: 28rpx;
+			}
+		}
+
+		&-line {
+			width: 100%;
+			height: 2rpx;
+			background-color: rgba(204, 204, 204, 1);
+			margin: 10rpx 0 0;
+		}
+		&-items {
+			padding: 30rpx;
+		
+			&-desc {
+				display: flex;
+		
+				&-right {
+					width: 80%;
+					margin-left: 20rpx;
+					margin-top: 15rpx;
+		
+					&-author {
+						display: flex;
+						align-items: center;
+						justify-content: space-between;
+		
+						&-name {
+							color: #343434;
+							font-size: 28rpx;
+						}
+		
+						&-sup {
+							color: #9A9A9A;
+							font-size: 24rpx;
+							display: flex;
+							align-items: center;
+		
+							text {
+								margin-right: 10rpx;
+							}
+						}
+					}
+		
+					&-date {
+						color: #9A9A9A;
+						font-size: 24rpx;
+						margin: 10rpx 0;
+					}
+		
+					&-desc {
+						color: #666666;
+						font-size: 28rpx;
+						display: inline-block;
+						text-align: justify;
+					}
+				}
+		
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_mine/lock/index.vue b/pages/sub_mine/lock/index.vue
new file mode 100644
index 0000000..22886de
--- /dev/null
+++ b/pages/sub_mine/lock/index.vue
@@ -0,0 +1,177 @@
+<template>
+	<view class="lock">
+		<view class="lock-avatar">
+			<u-avatar src="" mode="circle" size="120"></u-avatar>
+		</view>
+		<view class="lock-con">
+			<mpvue-gesture-lock :containerWidth="590" :cycleRadius="50" @end="onEnd" :password="password"></mpvue-gesture-lock>
+		</view>
+		<view class="lock-text">{{text}}</view>
+	</view>
+</template>
+
+<script>
+	import mpvueGestureLock from '../z_component/mpvueGestureLock/index.vue';
+	const app = getApp()
+	export default {
+		components: {
+			mpvueGestureLock
+		},
+		data() {
+			return {
+				password: [],
+				text: '请设置手势',
+				a: []
+			}
+		},
+		onLoad() {
+			let pwd = wx.getStorageSync("hands")
+			if (pwd) {
+				this.password = pwd
+				this.text = "请确认你的手势"
+			}
+		},
+		methods: {
+			login() {
+				let that = this
+				let tel = uni.getStorageSync('phone')
+				let pwd = uni.getStorageSync('pwd')
+				
+				// #ifdef APP-PLUS
+				let uuid = app.globalData.clientid ? app.globalData.clientid : ''
+				let platform = uni.getStorageSync('platform') ? 'App-' + uni.getStorageSync('platform') : ''
+				let a = atob(pwd.substr(1))
+				// #endif
+				
+				// #ifdef MP-WEIXIN
+				let a = pwd.substr(1)
+				let uuid = ''
+				let platform = uni.getStorageSync('platform') ? 'Wechat-' + uni.getStorageSync('platform') : ''
+				// #endif
+				
+				// #ifdef H5
+				let platform = 'H5'
+				let uuid = ''
+				let a= atob(pwd.substr(1))
+				// #endif
+				
+				let params = {
+					username: tel,
+					password: a,
+					deviceid: uuid,
+					platform: platform
+				}
+				
+				that.$u.post('/login',params).then(res => {
+					uni.setStorageSync("token", res.token)
+					uni.setStorageSync("uid", res.uid)
+					uni.setStorageSync("userid", res.userid)
+					uni.setStorageSync("tenantid", res.tenantid)
+					uni.setStorageSync("tokenexpire", res.expire)
+					uni.setStorageSync("tokentime", res.now)
+					uni.setStorageSync("signed", res.signed)
+					uni.setStorageSync("paypwdset", res.paypwdset)
+					uni.setStorageSync("name", res.name)
+					uni.setStorageSync("localpwd", res.localpwd)
+					uni.setStorageSync("phoneX", res.phone)
+					uni.setStorageSync("imgurl", res.imgurl)
+					uni.setStorageSync("idno", res.idno)
+					uni.setStorageSync("cardno", res.citizenCardNo)
+					uni.setStorageSync("bankcardno", res.bankCardNo)
+					if(res.needcheck){
+						uni.navigateTo({
+							url:'/pages/sub_basic/verification/index?data=' + JSON.stringify(params)
+						})
+						return false
+					}
+					uni.showToast({
+						title: "登录成功",
+						icon: "none",
+						mask:true,
+						duration: 800,
+						complete(res) {
+							setTimeout(() => {
+								uni.switchTab({
+									url: "/pages/sub_tabbar/index"
+								})
+							}, 1500)
+						}
+					})
+				})
+			},
+			onEnd(data) {
+				let that = this
+				that.a = data
+				let pwd = wx.getStorageSync("hands")
+				if (pwd) {
+					if (pwd.join('') === data.join('')) {
+						let login = uni.getStorageSync("login")
+						if(login){
+							that.text = '手势正确,即将进入首页'
+							uni.removeStorageSync("login")
+							that.login()
+						}else{
+							that.text = '手势正确,关闭手势成功'
+							uni.removeStorageSync("hands")
+							setTimeout(() => {
+								uni.navigateBack({
+									delta:1
+								})
+							}, 1000)
+						}
+						
+					} else {
+						that.text = '当前手势与原手势不一致,请确认后重新绘制'
+					}
+				} else {
+					if (that.password.length) {
+						if (that.password.length < 3) {
+							that.text = "所连接的圆圈数量不得少于3个"
+							that.password = []
+						} else {
+							if (that.password.join('') === data.join('')) {
+								that.text = '手势设定完成'
+								wx.setStorageSync("hands", that.password)
+								setTimeout(() => {
+									uni.navigateBack({
+										delta:1
+									})
+								}, 1000)
+							} else {
+								that.text = '两次手势设定不一致,请重新设置'
+								that.password = []
+							}
+						}
+					} else {
+						that.text = '请确认手势'
+						that.password = data
+					}
+				}
+			}
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.lock {
+		width: 100vw;
+		height: 100vh;
+		background-color: #FFFFFF;
+		overflow: hidden;
+		font-family: "PingFang-SC-Medium";
+
+		&-avatar {
+			display: flex;
+			justify-content: center;
+			margin: 50rpx 0;
+		}
+
+		&-text {
+			display: flex;
+			justify-content: center;
+			font-size: 30rpx;
+			color: #666666;
+			margin-top: 50rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/message/index.vue b/pages/sub_mine/message/index.vue
new file mode 100644
index 0000000..6eba995
--- /dev/null
+++ b/pages/sub_mine/message/index.vue
@@ -0,0 +1,183 @@
+<template>
+	<view class="message">
+		<u-sticky>
+			<view class="message-tabs">
+				<u-tabs :list="tabs" :current="current" @change="change" bar-width="250" item-width="250" :is-scroll="false"
+				 bar-height="3"></u-tabs>
+			</view>
+		</u-sticky>
+		<view class="message-list">
+			<view v-if="current==1">
+				<scroll-view :scroll-y="true" class="scrollView" @scrolltolower="getMoreLeaveList">
+					<u-swipe-action :show="v.show" :index="i"
+					 v-for="(v, i) in leaveMsg" :key="v.fbid"
+					 @content-click="toPath('/pages/sub_mine/leaveMsgDetail/index?id='+v.fbid)"
+					 @click="click"
+					 @open="open"
+					 @close="close"
+					 :options="options"
+					 v-if="v.isdelete =='0' ">
+						<view class="item u-border-bottom">
+							<view class="title-wrap">
+								<u-cell-group :border="false">
+									<u-cell-item :title="v.title" :arrow="true" :label="v.fbtime" value="查看详情" :center="true"></u-cell-item>
+								</u-cell-group>
+							</view>
+						</view>
+					</u-swipe-action>
+					<u-loadmore :status="status" :icon-type="iconType" :load-text="loadText" margin-top="30" />
+				</scroll-view>
+			</view>
+			<u-empty text="暂无消息" mode="message" margin-top="300" v-if="current !=1"></u-empty>
+		</view>
+
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				tabs: [{
+					name: "推送消息"
+				}, {
+					name: "留言消息"
+				}, {
+					name: "其他消息"
+				}],
+				current: 1,
+				list: [],
+				loadText: {
+					loadmore: '轻轻上拉',
+					loading: '努力加载中',
+					nomore: '暂无更多'
+				},
+				status: "loadmore",
+				iconType: 'circle',
+				pageno: 1,
+				leaveMsg: [],
+				options: [{
+					text: '删除',
+					style: {
+						backgroundColor: '#dd524d'
+					}
+				}]
+			}
+		},
+		methods: {
+			change(index) {
+				let that = this
+				that.current = index
+				that.leaveMsg.forEach(item => {
+					item.show = false
+				})
+			},
+			open(index) {
+				let that = this
+				that.leaveMsg.forEach(item => {
+					item.show = false
+				})
+				that.leaveMsg[index].show = true
+
+			},
+			close(index) {
+				let that = this
+				that.leaveMsg[index].show = false
+			},
+			click(index) {
+				let that = this
+				let fbid = that.leaveMsg[index].fbid
+				//console.log(that.leaveMsg)
+				uni.showModal({
+					title: "提示",
+					content: "确定要删除这条留言吗?",
+					success(res) {
+						if (res.confirm) {
+							that.$u.post('v1/feedback/delete/' + fbid, {}).then(res => {
+								that.leaveMsg[index].show = false
+								that.leaveMsg.splice(index, 1)
+								uni.showToast({
+									title: "您已成功删除此留言",
+									icon: "none",
+									duration: 1500
+								})
+							}).catch(res => {
+								that.leaveMsg[index].show = false
+							})
+						} else if (res.cancel) {
+							that.leaveMsg[index].show = false
+						}
+					}
+				})
+			},
+			getLeaveMsgList(no) {
+				let that = this
+				let params = {
+					pageno: no,
+					pagesize: 10
+				}
+				that.$u.get("/v1/feedback/list", params).then(res => {
+					let list = res.data.list
+					let total = res.data.totalCount
+					let page = res.data.totalPage
+					if (no > page) {
+						that.status = "nomore"
+						return false
+					}
+					//console.log(total,list.length)
+					if (list.length) {
+						if (list.length >= total) {
+							that.status = "nomore"
+						} else {
+							that.status = "loadmore"
+							that.pageno += 1
+						}
+						list.forEach(item => {
+							item.fbtime = item.fbtime.substr(0, 4) + "-" + item.fbtime.substr(4, 2) + "-" + item.fbtime.substr(6, 2) +
+								" " + item.fbtime.substr(8, 2) + ":" + item.fbtime.substr(10, 2) + ":" + item.fbtime.substr(12, 2);
+							item.show = false
+						})
+						that.leaveMsg = that.leaveMsg.concat(list)
+						//console.log(list)
+					} else {
+						that.leaveMsg = that.leaveMsg.concat(list)
+						that.status = "nomore"
+					}
+
+				})
+			},
+			getMoreLeaveList() {
+				let that = this
+				let pageno = that.pageno
+				if (that.status != "nomore") {
+					that.getLeaveMsgList(pageno)
+				}
+			}
+		},
+		onLoad() {
+			this.getLeaveMsgList(this.pageno)
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+	.scrollView {
+		height: calc(100vh - 80rpx);
+	}
+
+	.message {
+		height: 100vh;
+		background-color: #FFFFFF;
+
+		&-list {
+			&-item {
+				font-size: 40rpx;
+				font-weight: bold;
+				font-family: "PingFang-SC-Medium";
+				display: flex;
+				justify-content: center;
+				margin-top: 50rpx;
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_mine/otherLogin/index.vue b/pages/sub_mine/otherLogin/index.vue
new file mode 100644
index 0000000..b3508ab
--- /dev/null
+++ b/pages/sub_mine/otherLogin/index.vue
@@ -0,0 +1,166 @@
+<template>
+	<view class="otherLogin">
+		<u-cell-group>
+			<u-cell-item title="指纹" :arrow="false">
+				<u-icon slot="icon" size="32" name="fingerprint"></u-icon>
+				<u-switch slot="right-icon" v-model="fingerprint" @change="finger"></u-switch>
+			</u-cell-item>
+			<u-cell-item title="手势" :arrow="false">
+				<u-icon name="hands" custom-prefix="custom-icon" size="32" slot="icon"></u-icon>
+				<u-switch slot="right-icon" v-model="hands" @change="openHands"></u-switch>
+			</u-cell-item>
+			<u-cell-item title="人脸" :arrow="false">
+				<u-icon name="face" custom-prefix="custom-icon" size="32" slot="icon"></u-icon>
+				<u-switch slot="right-icon" v-model="face" @change="openFace"></u-switch>
+			</u-cell-item>
+		</u-cell-group>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				fingerprint: false,
+				hands: false,
+				face: false,
+				list: []
+			}
+		},
+		onShow() {
+			let hands = wx.getStorageSync("hands")
+			let face = wx.getStorageSync("face")
+			let fingerprint = wx.getStorageSync("fingerprint")
+			this.hands = hands.length > 0 ? true : false
+			this.face = face ? true : false
+			this.fingerprint = fingerprint ? true : false
+		},
+		onLoad() {
+
+		},
+		methods: {
+			finger(e) {
+				let that = this
+				if (e) {
+					uni.checkIsSupportSoterAuthentication({
+						success(res) {
+							let str = res.supportMode.join("")
+							if (str.indexOf("fingerPrint") != -1) {
+								uni.setStorageSync("fingerprint", true)
+								uni.showToast({
+									title:'开启指纹解锁成功',
+									icon:'none'
+								})
+								//plus.nativeUI.toast("开启指纹解锁成功");
+								that.fingerprint = true
+							} else {
+								uni.showToast({
+									title:'该设备不支持指纹解锁',
+									icon:'none'
+								})
+								//plus.nativeUI.toast("该设备不支持指纹解锁");
+								that.fingerprint = false
+							}
+						},
+						fail(res) {
+							uni.showToast({
+								title:'开启指纹解锁失败',
+								icon:'none'
+							})
+							//plus.nativeUI.toast("开启指纹解锁失败");
+							that.fingerprint = false
+						}
+					})
+				} else {
+					uni.removeStorageSync("fingerprint")
+				}
+
+
+			},
+			openFace(e) {
+				let that = this
+				if (e) {
+					uni.checkIsSupportSoterAuthentication({
+						success(res) {
+							let str = res.supportMode.join("")
+							if (str.indexOf("facial") == -1) {
+								uni.showToast({
+									title:'该设备不支持面容解锁',
+									icon:'none'
+								})
+								//plus.nativeUI.toast("该设备不支持面容解锁");
+								that.face = false
+							} else {
+								uni.showToast({
+									title:'开启棉柔解锁成功',
+									icon:'none'
+								})
+								uni.setStorageSync("face", true)
+								that.face = true
+								//plus.nativeUI.toast("开启棉柔解锁成功");
+							}
+						},
+						fail(res) {
+							uni.showToast({
+								title:'开启面容识别失败',
+								icon:'none'
+							})
+							//plus.nativeUI.toast("开启面容识别失败");
+							that.face = false
+						}
+					})
+				} else {
+					uni.removeStorageSync("face")
+				}
+			},
+			openHands(e) {
+				if (e) {
+					uni.navigateTo({
+						url: "/pages/sub_mine/lock/index"
+					})
+				} else {
+					uni.showModal({
+						title: "提示",
+						content: "确定关闭手势解锁吗?",
+						success: (res) => {
+							if (res.confirm) {
+								uni.navigateTo({
+									url: "/pages/sub_mine/lock/index"
+								})
+							} else if (res.cancel) {
+								this.hands = true
+							}
+						}
+					})
+				}
+			}
+
+		}
+	}
+	// uni.checkIsSoterEnrolledInDevice({
+	// 	checkAuthMode: 'fingerPrint',
+	// 	success(res) {
+	// 		if (res.isEnrolled) {
+	// 			uni.startSoterAuthentication({
+	// 				requestAuthModes: ['fingerPrint'],
+	// 				authContent: e ? '开启指纹解锁' : "关闭指纹解锁",
+	// 				success(res) {
+	// 					console.log(res);
+	// 					this.fingerprint = true
+	// 				},
+	// 				fail(res) {
+	// 					plus.nativeUI.toast("使用指纹失败");
+	// 					this.fingerprint = false
+	// 				}
+	// 			})
+	// 		} else {
+	// 			plus.nativeUI.toast("没有录入指纹");
+	// 			this.fingerprint = false
+	// 		}
+	// 	},
+	// })
+</script>
+
+<style scoped lang="scss">
+
+</style>
diff --git a/pages/sub_mine/otherPay/index.vue b/pages/sub_mine/otherPay/index.vue
new file mode 100644
index 0000000..92a5fee
--- /dev/null
+++ b/pages/sub_mine/otherPay/index.vue
@@ -0,0 +1,63 @@
+<template>
+	<view class="otherPay">
+		<u-cell-group>
+			<u-cell-item title="指纹" :arrow="false">
+				<u-icon slot="icon" size="32" name="fingerprint"></u-icon>
+				<u-switch slot="right-icon" v-model="checked" @change="isOtherPay"></u-switch>
+			</u-cell-item>
+		</u-cell-group>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				checked: false
+			}
+		},
+		onLoad() {
+			let that = this
+			let openFingerPay = wx.getStorageSync("openFingerPay")
+			if (openFingerPay) {
+				that.checked = true
+			}
+		},
+		methods: {
+			isOtherPay(e) {
+				let that = this
+				if (e) {
+					uni.showModal({
+						title: "提示",
+						content: "是否开启指纹支付",
+						complete(res) {
+							if (res.confirm) {
+								that.checked = true
+								uni.setStorageSync("openFingerPay", true)
+							} else if (res.cancel) {
+								that.checked = false
+							}
+						}
+					})
+				} else {
+					uni.showModal({
+						title: "提示",
+						content: "是否关闭指纹支付",
+						complete(res) {
+							if (res.confirm) {
+								that.checked = false
+								uni.removeStorageSync("openFingerPay")
+							} else if (res.cancel) {
+								that.checked = true
+							}
+						}
+					})
+				}
+			}
+		}
+	}
+</script>
+
+<style scoped lang="scss">
+
+</style>
diff --git a/pages/sub_mine/personalMsg/index.vue b/pages/sub_mine/personalMsg/index.vue
new file mode 100644
index 0000000..36960ea
--- /dev/null
+++ b/pages/sub_mine/personalMsg/index.vue
@@ -0,0 +1,64 @@
+<template>
+	<view class="personalMsg">
+		<view class="personalMsg-list">
+			<u-cell-item title="姓名" :arrow="false" :value="name"></u-cell-item>
+			<u-cell-item title="手机号" :arrow="false" :value="tel"></u-cell-item>
+			<u-cell-item title="银行卡号" :arrow="false" :value="bankcardno"></u-cell-item>
+			<u-cell-item title="市民卡号" :arrow="false" :value="cardno"></u-cell-item>
+			<u-cell-item title="身份证号" :arrow="false" :value="idno"></u-cell-item>
+			<u-cell-item title="身份状态" :arrow="false" :value="signed"></u-cell-item>
+			<!-- <u-field v-model="name" :disabled="true" label="姓名" :field-style="fieldStyle" clear-size="40" input-align="right"></u-field>
+			<u-field v-model="tel" :disabled="true" label="手机号" :field-style="fieldStyle" clear-size="40" input-align="right"></u-field>
+			<u-field v-model="bankcardno" :disabled="true" label="银行卡号" :field-style="fieldStyle" clear-size="40" input-align="right"></u-field>
+			<u-field v-model="cardno" :disabled="true" label="市民卡号" :field-style="fieldStyle" clear-size="40" input-align="right"></u-field>
+			<u-field v-model="idno" :disabled="true" label="身份证号" :field-style="fieldStyle" clear-size="40" input-align="right"></u-field>
+			<u-field v-model="signed" :disabled="true" label="身份状态" :field-style="fieldStyle" clear-size="40" input-align="right"></u-field> -->
+		</view>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				fieldStyle: {
+					'font-size': '30rpx',
+					'color': '#333333'
+				},
+				name:'',
+				bankcardno:'',
+				cardno:'',
+				idno:'',
+				signed:'',
+				tel:''
+			}
+		},
+		methods: {
+			
+		},
+		onLoad() {
+			let that = this
+			that.name = uni.getStorageSync('name')?uni.getStorageSync('name'):'佚名'
+			that.bankcardno = uni.getStorageSync('bankcardno')?uni.getStorageSync('bankcardno'):'暂无银行卡信息'
+			that.cardno = uni.getStorageSync('cardno')?uni.getStorageSync('cardno').substr(0,2) + '****' + uni.getStorageSync('cardno').substr(6,2):'暂无市民卡信息'
+			that.idno = uni.getStorageSync('idno')?uni.getStorageSync('idno'):'暂无身份证信息'
+			that.signed = uni.getStorageSync('signed') == 'yes' ? '已绑定签约':'未绑定'
+			that.tel = uni.getStorageSync('phoneX') ? uni.getStorageSync('phoneX') : '暂无手机号'
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.personalMsg {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		&-list {
+			background-color: #FFFFFF;
+			margin-top: 30rpx;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/reportheLoss/index.vue b/pages/sub_mine/reportheLoss/index.vue
new file mode 100644
index 0000000..d3a3cb6
--- /dev/null
+++ b/pages/sub_mine/reportheLoss/index.vue
@@ -0,0 +1,112 @@
+<template>
+	<view class="loss">
+		<view class="loss-list">
+			<u-field v-model="name" :disabled="true" label="姓名" :field-style="fieldStyle" clear-size="40"></u-field>
+			<u-field v-model="idno" :disabled="true" label="身份证号" :field-style="fieldStyle" clear-size="40"></u-field>
+			<u-field v-model="cardno" :disabled="true" label="市民卡号" :field-style="fieldStyle" clear-size="40"></u-field>
+			<u-field v-model="pwd" label="支付密码" placeholder="请输入6位密码" placeholder-style="color:#999999" maxlength="6" :password="true"
+			 type="number" clear-size="40"></u-field>
+		</view>
+		<u-button :custom-style="lossBtn" @click="reportLoss">挂失</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				name: "",
+				idno: "",
+				cardno: "",
+				pwd: "",
+				fieldStyle: {
+					'font-size': '30rpx',
+					'color': '#333333'
+				},
+				lossBtn:{
+					width: '600rpx',
+					backgroundColor: '#2FA8E1',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '100rpx',
+					padding: '50rpx 0'
+				}
+			}
+		},
+		onLoad() {
+			let that = this
+			let idno = uni.getStorageSync("idno") ? uni.getStorageSync("idno") : "暂无"
+			let name = uni.getStorageSync("name") ? uni.getStorageSync("name") : "佚名"
+			let cardno = uni.getStorageSync("cardno") ? uni.getStorageSync('cardno').substr(0,2) + '****' + uni.getStorageSync('cardno').substr(6,2) : "暂无"
+			that.name = name
+			that.idno = idno
+			that.cardno = cardno
+		},
+		methods: {
+			reportLoss() {
+				let that = this
+				let pwd = that.pwd
+				if (pwd == "") {
+					uni.showToast({
+						title: "请输入支付密码",
+						duration: 800,
+						icon: "none"
+					})
+					return false
+				}
+				uni.showModal({
+					title: "提示",
+					content: "确定要挂失市民卡吗",
+					complete(res) {
+						if (res.confirm) {
+							let param = {
+								"paypwd": pwd
+							}
+							that.$u.post("/v1/cardlost", param).then((res) => {
+								uni.showToast({
+									title: "挂失成功",
+									icon: "none",
+									duration: 800,
+									complete(res) {
+										setTimeout(() => {
+											uni.switchTab({
+												url: "/pages/sub_tabbar/index"
+											})
+										}, 1500)
+									}
+								})
+							})
+						}
+					}
+				})
+			}
+
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.loss {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		&-list {
+			background-color: #FFFFFF;
+			margin-top: 30rpx;
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 100rpx;
+			padding: 50rpx 0;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/unbindBankCard/index.vue b/pages/sub_mine/unbindBankCard/index.vue
new file mode 100644
index 0000000..9209f80
--- /dev/null
+++ b/pages/sub_mine/unbindBankCard/index.vue
@@ -0,0 +1,108 @@
+<template>
+	<view class="unbindBankCard">
+		<view class="unbindBankCard-list">
+			<u-field v-model="name" :disabled="true" label="姓名" :field-style="fieldStyle" clear-size="40"></u-field>
+			<u-field v-model="bankno" :disabled="true" label="银行卡号" :field-style="fieldStyle" clear-size="40"></u-field>
+			<u-field v-model="status" :disabled="true" label="状态" :field-style="fieldStyle" clear-size="40"></u-field>
+			<u-field v-model="pwd" label="支付密码" placeholder="请输入6位支付密码" placeholder-style="color:#999999" maxlength="6"
+			 :password="true"
+			 type="number" clear-size="40"></u-field>
+		</view>
+		<u-button :custom-style="unbindBankCardBtn" @click="unbind">解除绑定</u-button>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				name: "暂无",
+				bankno: "暂无",
+				status: "暂无",
+				pwd: "",
+				fieldStyle: {
+					'font-size': '30rpx',
+					'color': '#333333'
+				},
+				unbindBankCardBtn:{
+					width: '600rpx',
+					backgroundColor: '#fa3534',
+					color: '#FFFFFF',
+					fontFamily: "PingFang-SC-Medium",
+					fontSize: '30rpx',
+					marginTop: '150rpx',
+					padding: '50rpx 0'
+				}
+			}
+		},
+		methods: {
+			getCardsiInfor() {
+				let that = this
+				that.$u.post("/v1/cardinfor").then((res) => {
+					that.name = res.name
+					that.status = res.cardstatus
+					that.bankno = res.cardno
+				})
+			},
+			unbind() {
+				let that = this
+				let pwd = that.pwd
+				if (pwd == "") {
+					uni.showToast({
+						title: "请输入您的支付密码",
+						icon: "none",
+						duration: 800
+					})
+					return false
+				}
+				let param = {
+					paypwd: pwd
+				}
+				that.$u.post("/v1/unsignbxy", param).then((res) => {
+					uni.setStorageSync("signed", "")
+					uni.showToast({
+						title: "解绑成功",
+						icon: "none",
+						duration: 800,
+						complete(res) {
+							setTimeout(() => {
+								uni.navigateBack({
+									delta: 1
+								})
+							}, 1500)
+						}
+					})
+				})
+			}
+		},
+		onLoad() {
+			this.getCardsiInfor()
+		}
+
+	}
+</script>
+
+<style lang="scss" scoped>
+	.unbindBankCard {
+		width: 100vw;
+		// height: 100vh;
+		background-color: #F3F3F3;
+		overflow: hidden;
+		padding-bottom: 30rpx;
+
+		&-list {
+			background-color: #FFFFFF;
+			margin-top: 30rpx;
+		}
+
+		&-btn {
+			width: 600rpx;
+			background-color: #2FA8E1;
+			color: #FFFFFF;
+			font-family: "PingFang-SC-Medium";
+			font-size: 30rpx;
+			margin-top: 150rpx;
+			padding: 50rpx 0;
+		}
+	}
+</style>
diff --git a/pages/sub_mine/voucher/index.vue b/pages/sub_mine/voucher/index.vue
new file mode 100644
index 0000000..3ac4cf5
--- /dev/null
+++ b/pages/sub_mine/voucher/index.vue
@@ -0,0 +1,11 @@
+<template>
+	<view class="voucher">
+		<u-empty text="暂无卡券" mode="coupon" margin-top="300"></u-empty>
+	</view>
+</template>
+
+<script>
+</script>
+
+<style>
+</style>
diff --git a/pages/sub_mine/z_component/mpvueGestureLock/gestureLock.js b/pages/sub_mine/z_component/mpvueGestureLock/gestureLock.js
new file mode 100644
index 0000000..21cf459
--- /dev/null
+++ b/pages/sub_mine/z_component/mpvueGestureLock/gestureLock.js
@@ -0,0 +1,175 @@
+class GestureLock {
+
+    constructor(containerWidth, cycleRadius) {
+        this.containerWidth = containerWidth; // 容器宽度
+        this.cycleRadius = cycleRadius; // 圆的半径
+
+        this.circleArray = []; // 全部圆的对象数组
+        this.checkPoints = []; // 选中的圆的对象数组
+        this.lineArray = []; // 已激活锁之间的线段数组
+        this.lastCheckPoint = 0; // 最后一个激活的锁
+        this.offsetX = 0; // 容器的 X 偏移
+        this.offsetY = 0; // 容器的 Y 偏移
+        this.activeLine = {}; // 最后一个激活的锁与当前位置之间的线段
+
+        this.windowWidth = wx.getSystemInfoSync().windowWidth; // 窗口大小(用于rpx 和 px 转换)
+
+        this.initCircleArray();
+    }
+
+    // 初始化 画布上的 9个圆
+    initCircleArray() {
+        const cycleMargin = (this.containerWidth - 6 * this.cycleRadius) / 6;
+        let count = 0;
+        for (let i = 0; i < 3; i++) {
+            for (let j = 0; j < 3; j++) {
+                count++;
+                this.circleArray.push({
+                    count: count,
+                    x: this.rpxTopx((cycleMargin + this.cycleRadius) * (j * 2 + 1)),
+                    y: this.rpxTopx((cycleMargin + this.cycleRadius) * (i * 2 + 1)),
+                    radius: this.rpxTopx(this.cycleRadius),
+                    check: false,
+                    style: {
+                        left: (cycleMargin + this.cycleRadius) * (j * 2 + 1) - this.cycleRadius + 'rpx',
+                        top: (cycleMargin + this.cycleRadius) * (i * 2 + 1) - this.cycleRadius + 'rpx',
+                        width: this.cycleRadius * 2 + 'rpx',
+                    }
+                });
+            }
+        }
+    }
+
+    onTouchStart(e) {
+        this.setOffset(e);
+        this.checkTouch({
+            x: e.touches[0].pageX - this.offsetX,
+            y: e.touches[0].pageY - this.offsetY
+        });
+    }
+
+    onTouchMove(e) {
+        this.moveDraw(e)
+    }
+
+    onTouchEnd(e) {
+        const checkPoints = this.checkPoints;
+        this.reset();
+        return checkPoints;
+    }
+
+    // 初始化 偏移量
+    setOffset(e) {
+        this.offsetX = e.currentTarget.offsetLeft;
+        this.offsetY = e.currentTarget.offsetTop;
+    }
+
+    // 检测当时 触摸位置是否位于 锁上
+    checkTouch({
+        x,
+        y
+    }) {
+        for (let i = 0; i < this.circleArray.length; i++) {
+            let point = this.circleArray[i];
+            if (this.isPointInCycle(x, y, point.x, point.y, point.radius)) {
+                if (!point.check) {
+                    this.checkPoints.push(point.count);
+                    if (this.lastCheckPoint != 0) {
+                        // 已激活锁之间的线段
+                        const line = this.drawLine(this.lastCheckPoint, point);
+                        this.lineArray.push(line);
+                    }
+                    this.lastCheckPoint = point;
+                }
+                point.check = true;
+                return;
+            }
+        }
+    }
+
+    // 画线 - 返回 样式 对象
+    drawLine(start, end) {
+        const width = this.getPointDis(start.x, start.y, end.x, end.y);
+        const rotate = this.getAngle(start, end);
+
+        return {
+            activeLeft: start.x + 'px',
+            activeTop: start.y + 'px',
+            activeWidth: width + 'px',
+            activeRotate: rotate + 'deg'
+        }
+
+    }
+
+    // 获取 画线的 角度
+    getAngle(start, end) {
+        var diff_x = end.x - start.x,
+            diff_y = end.y - start.y;
+        if (diff_x >= 0) {
+            return 360 * Math.atan(diff_y / diff_x) / (2 * Math.PI);
+        } else {
+            return 180 + 360 * Math.atan(diff_y / diff_x) / (2 * Math.PI);
+        }
+    }
+
+    // 判断 当前点是否位于 锁内
+    isPointInCycle(x, y, circleX, circleY, radius) {
+        return (this.getPointDis(x, y, circleX, circleY) < radius) ? true : false;
+    }
+
+    // 获取两点之间距离
+    getPointDis(ax, ay, bx, by) {
+        return Math.sqrt(Math.pow(ax - bx, 2) + Math.pow(ay - by, 2));
+    }
+
+    // 移动 绘制
+    moveDraw(e) {
+        // 画经过的圆
+        const x = e.touches[0].pageX - this.offsetX;
+        const y = e.touches[0].pageY - this.offsetY;
+        this.checkTouch({
+            x,
+            y
+        });
+
+        // 画 最后一个激活的锁与当前位置之间的线段
+        this.activeLine = this.drawLine(this.lastCheckPoint, {
+            x,
+            y
+        });
+    }
+
+    // 使 画布 恢复初始状态
+    reset() {
+        this.circleArray.forEach((item) => {
+            item.check = false;
+        });
+        this.checkPoints = [];
+        this.lineArray = [];
+        this.activeLine = {};
+        this.lastCheckPoint = 0;
+    }
+
+
+    // 获取 最后一个激活的锁与当前位置之间的线段
+    getActiveLine() {
+        return this.activeLine;
+    }
+
+    // 获取 圆对象数组
+    getCycleArray() {
+        return this.circleArray;
+    }
+
+    // 获取 已激活锁之间的线段
+    getLineArray() {
+        return this.lineArray;
+    }
+
+    // 将 RPX 转换成 PX
+    rpxTopx(rpx) {
+        return rpx / 750 * this.windowWidth;
+    }
+}
+
+export default GestureLock;
diff --git a/pages/sub_mine/z_component/mpvueGestureLock/index.vue b/pages/sub_mine/z_component/mpvueGestureLock/index.vue
new file mode 100644
index 0000000..b2d7138
--- /dev/null
+++ b/pages/sub_mine/z_component/mpvueGestureLock/index.vue
@@ -0,0 +1,132 @@
+<template>
+	<div class="gesture-lock" :class="{error:error}" :style="{width: containerWidth +'rpx', height:containerWidth +'rpx'}"
+	 @touchstart.stop="onTouchStart" @touchmove.stop="onTouchMove" @touchend.stop="onTouchEnd" @touchmove.stop.prevent="moveHandle">
+		<!-- 9 个圆 -->
+		<div v-for="(item,i) in circleArray" :key="'cycle'+ i" class="cycle" :class="{check:item.check}" :style="{left:item.style.left,top:item.style.top,width:item.style.width,height:item.style.width}">
+		</div>
+
+		<!-- 已激活锁之间的线段 -->
+		<div v-for="(item,i) in lineArray" :key="'line' + i" class="line" :style="{left:item.activeLeft,top:item.activeTop,width:item.activeWidth,transform:'rotate('+item.activeRotate+')'}">
+		</div>
+
+		<!-- 最后一个激活的锁与当前位置之间的线段 -->
+		<div class="line" :style="{left:activeLine.activeLeft,top:activeLine.activeTop,width:activeLine.activeWidth,transform:'rotate('+activeLine.activeRotate+')'}">
+		</div>
+	</div>
+</template>
+
+<script>
+	import GestureLock from './gestureLock';
+
+	export default {
+		name: 'index',
+		props: {
+			/**
+			 * 容器宽度
+			 */
+			containerWidth: [Number, String],
+			/**
+			 * 圆的半径
+			 */
+			cycleRadius: [Number, String],
+			/**
+			 * 已设定的密码
+			 */
+			password: {
+				type: Array,
+				default: []
+			},
+		},
+		data() {
+			return {
+				gestureLock: {}, // 锁对象
+				circleArray: [], // 圆对象数组
+				lineArray: [], // 已激活锁之间的线段
+				activeLine: {}, // 最后一个激活的锁与当前位置之间的线段
+				error: false
+			}
+		},
+		methods: {
+			onTouchStart(e) {
+				this.gestureLock.onTouchStart(e);
+				this.refesh();
+			},
+
+			onTouchMove(e) {
+				this.gestureLock.onTouchMove(e);
+				this.refesh();
+			},
+			moveHandle() {
+				return;
+			},
+			onTouchEnd(e) {
+				const checkPoints = this.gestureLock.onTouchEnd(e);
+				if (!this.password.length || checkPoints.join('') == this.password.join('')) {
+					this.refesh();
+					this.$emit('end', checkPoints);
+				} else {
+					this.error = true;
+					setTimeout(() => {
+						this.refesh();
+						this.$emit('end', checkPoints);
+					}, 800);
+				}
+
+			},
+			refesh() {
+				this.error = false;
+				this.circleArray = this.gestureLock.getCycleArray();
+				this.lineArray = this.gestureLock.getLineArray();
+				this.activeLine = this.gestureLock.getActiveLine();
+			}
+		},
+		mounted() {
+			this.gestureLock = new GestureLock(this.containerWidth, this.cycleRadius);
+			this.refesh();
+		}
+	}
+</script>
+
+<style scoped>
+	.gesture-lock {
+		margin: 0 auto;
+		position: relative;
+		box-sizing: border-box;
+		overflow: auto;
+	}
+
+	.gesture-lock .cycle {
+		box-sizing: border-box;
+		position: absolute;
+		/* border: 2px solid #66aaff; */
+		background-color: #97DEFF;
+		border-radius: 50%;
+	}
+
+	.gesture-lock .cycle.check:after {
+		content: "";
+		display: block;
+		position: absolute;
+		width: 32%;
+		height: 32%;
+		/* border: 2px solid #66aaff; */
+		background-color: #30A8E1;
+		border-radius: 50%;
+		top: 50%;
+		left: 50%;
+		transform: translate(-50%, -50%);
+	}
+
+	.gesture-lock .line {
+		height: 0;
+		border-top: 2px solid #CCEEFF;
+		position: absolute;
+		transform-origin: left center;
+	}
+
+	.gesture-lock.error .cycle.check,
+	.gesture-lock.error .cycle.check:after,
+	.gesture-lock.error .line {
+		border-color: #CCEEFF;
+	}
+</style>
diff --git a/pages/sub_mine/z_component/stan-ucharts/RingChart.vue b/pages/sub_mine/z_component/stan-ucharts/RingChart.vue
new file mode 100644
index 0000000..faba16b
--- /dev/null
+++ b/pages/sub_mine/z_component/stan-ucharts/RingChart.vue
@@ -0,0 +1,140 @@
+<template>
+	<view class="ring_chart">
+		<canvas :canvasId="canvasId" id="canvasId" :style="{ width: cWidth + 'px', height: cHeight + 'px' }" @touchstart="touchstart" />
+		<slot />
+	</view>
+</template>
+
+<script>
+	import uCharts from './u-charts.min.js'; //可以优化放全局 uCharts ==>使用全局
+	const ringCharts = {},
+		optionAs = {};
+	export default {
+		name: 'PieChart',
+		props: {
+			dataAs: {
+				//数据
+				type: Object,
+				default: () => ({})
+			},
+			basicAs: {
+				////通用基础项设置
+				type: Object,
+				default: () => ({})
+			},
+			titleAs: {
+				//只适用于适用于ring 环形、arcbar 弧线、gauge量规
+				type: Object,
+				default: () => ({})
+			},
+			legendAs: {
+				//图例设置
+				type: Object,
+				default: () => ({})
+			},
+			extraAs: {
+				//详情请看 http://doc.ucharts.cn/1172130
+				type: Object,
+				default: () => ({})
+			},
+			width: {
+				//图标宽度
+				type: Number,
+				default: 750
+			},
+			height: {
+				//图标高度
+				type: Number,
+				default: 500
+			},
+			valueKey: {
+				type: String,
+				default: 'series',
+			},
+			canvasId: {
+				type: String,
+				default: `ring_canvas_${Math.ceil(Math.random(5) * 10000)}`
+			}
+		},
+		data() {
+			return {};
+		},
+		computed: {
+			cWidth() {
+				return uni.upx2px(this.width);
+			},
+			cHeight() {
+				return uni.upx2px(this.height);
+			}
+		},
+		mounted() {
+			let defaultOption = {
+				//通用基础项设置 basicAs
+				$this: this, //this实例组件内使用图表,必须传入this实例
+				canvasId: this.canvasId, //页面组件canvas-id,支付宝中为id
+				type: 'ring', //图表类型,可选值为pie、line、column、area、ring、radar、arcbar、gauge、candle、bar、mix、rose、word
+				padding: [15, 15, 0, 15], //画布填充边距,顺序为上右下左,同css,但必须4位
+				colors: ['#30DCE1', '#AC96FC', '#6AC4FA', '#8EBAFF', '#30A8E1'], //图表配色方案,不传则使用系统默认配置
+				rotate: false, //是否横屏展示
+				rotateLock: false, //	锁定横屏模式,如果在支付宝和百度小程序中使用横屏模式,请赋值true,否则每次都会旋转90度。跨端使用通过uni-app的条件编译来赋值
+				animation: true, //是否动画展示
+				dataPointShape: true,
+				duration: 1000, //动画展示时长单位毫秒
+				fontSize: 12, //全局默认字体大小(可选,单位为px,默认13px)高分屏不必乘像素比,自动根据pixelRatio计算
+				background: '#ffffff', //canvas背景颜色(如果页面背景颜色不是白色请设置为页面的背景颜色,默认#ffffff)无作用
+				pixelRatio: 1, //像素比,默认为1,仅支付宝小程序需要大于1,其他平台必须为1
+				width: this.cWidth, //canvas宽度,单位为px,支付宝高分屏需要乘像素比(pixelRatio)
+				height: this.cHeight, //canvas高度,单位为px,支付宝高分屏需要乘像素比
+
+				//数据列表配置项 dataAS
+				series: this.dataAs[this.valueKey], //数据列表
+				// legendShape : "rect",
+				//图列配置 legendAs
+				legend: {
+					show: true, //是否显示各类别的图例标识
+					position: 'right',
+					margin: 30,
+					lineHeight: 30,
+					borderWidth: 20
+				},
+
+				//titleAs
+				title: {
+					name: ''
+				},
+				subtitle: {
+					name: ''
+				},
+
+				//扩展配置 extraAs 详情请看 http://doc.ucharts.cn/1172130
+				extra: {
+					pie: {
+						lableWidth: 15,
+						ringWidth: 20, //圆环的宽度
+						offsetAngle: 0 //圆环的角度
+					}
+				}
+			};
+			optionAs[this.canvasId] = Object.assign(defaultOption, this.basicAs, this.titleAs, this.legendAs, this.extraAs);
+			ringCharts[this.canvasId] = new uCharts(optionAs[this.canvasId]);
+		},
+		methods: {
+			touchstart(e) {
+				ringCharts[this.canvasId].touchLegend(e, {
+					animation: false
+				});
+				ringCharts[this.canvasId].showToolTip(e, {
+					format: function(item) {
+						if (typeof item.data === 'object') {
+							return `${item.name}:${item.data.value}`;
+						} else {
+							return `${item.name}:${item.data}`;
+						}
+					}
+				});
+			}
+		}
+	};
+</script>
+
+<style></style>
diff --git a/pages/sub_mine/z_component/stan-ucharts/u-charts.min.js b/pages/sub_mine/z_component/stan-ucharts/u-charts.min.js
new file mode 100644
index 0000000..ba10de5
--- /dev/null
+++ b/pages/sub_mine/z_component/stan-ucharts/u-charts.min.js
@@ -0,0 +1 @@
+'use strict';var config={yAxisWidth:15,yAxisSplit:5,xAxisHeight:15,xAxisLineHeight:15,legendHeight:15,yAxisTitleWidth:15,padding:[10,10,10,10],pixelRatio:1,rotate:!1,columePadding:3,fontSize:13,dataPointShape:["circle","circle","circle","circle"],colors:["#1890ff","#2fc25b","#facc14","#f04864","#8543e0","#90ed7d"],pieChartLinePadding:15,pieChartTextPadding:5,xAxisTextPadding:3,titleColor:"#333333",titleFontSize:20,subtitleColor:"#999999",subtitleFontSize:15,toolTipPadding:3,toolTipBackground:"#000000",toolTipOpacity:.7,toolTipLineHeight:20,radarLabelTextMargin:15,gaugeLabelTextMargin:15};let assign=function(e,...t){function i(e,t){for(let a in t)e[a]=e[a]&&"[object Object]"===e[a].toString()?i(e[a],t[a]):e[a]=t[a];return e}if(null==e)throw new TypeError("Cannot convert undefined or null to object");return!t||0>=t.length?e:(t.forEach(t=>{e=i(e,t)}),e)};var util={toFixed:function(e,t){return t=t||2,this.isFloat(e)&&(e=e.toFixed(t)),e},isFloat:function(e){return 0!=e%1},approximatelyEqual:function(e,t){return 1e-10>Math.abs(e-t)},isSameSign:function(e,t){var i=Math.abs;return i(e)===e&&i(t)===t||i(e)!==e&&i(t)!==t},isSameXCoordinateArea:function(e,t){return this.isSameSign(e.x,t.x)},isCollision:function(e,t){e.end={},e.end.x=e.start.x+e.width,e.end.y=e.start.y-e.height,t.end={},t.end.x=t.start.x+t.width,t.end.y=t.start.y-t.height;var i=t.start.x>e.end.x||t.end.x<e.start.x||t.end.y>e.start.y||t.start.y<e.end.y;return!i}};function getH5Offset(t){return t.mp={changedTouches:[]},t.mp.changedTouches.push({x:t.offsetX,y:t.offsetY}),t}function hexToRgb(e,t){var i=/^#?([a-f\d])([a-f\d])([a-f\d])$/i,a=e.replace(i,function(e,t,i,a){return t+t+i+i+a+a}),o=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(a),n=parseInt(o[1],16),l=parseInt(o[2],16),r=parseInt(o[3],16);return"rgba("+n+","+l+","+r+","+t+")"}function findRange(e,t,i){if(isNaN(e))throw new Error("[uCharts] unvalid series data!");i=i||10,t=t?t:"upper";for(var a=1;1>i;)i*=10,a*=10;for(e="upper"===t?Math.ceil(e*a):Math.floor(e*a);0!=e%i;)"upper"===t?e++:e--;return e/a}function calCandleMA(e,t,i,a){let o=[];for(let n,l=0;l<e.length;l++){n={data:[],name:t[l],color:i[l]};for(let t=0,i=a.length;t<i;t++){if(t<e[l]){n.data.push(null);continue}let i=0;for(let o=0;o<e[l];o++)i+=a[t-o][1];n.data.push(+(i/e[l]).toFixed(3))}o.push(n)}return o}function calValidDistance(e,t,i,a,o){var n=o.width-o.area[1]-o.area[3],l=i.eachSpacing*(o.chartData.xAxisData.xAxisPoints.length-1),r=t;return 0<=t?(r=0,e.event.trigger("scrollLeft")):Math.abs(t)>=l-n&&(r=n-l,e.event.trigger("scrollRight")),r}function isInAngleRange(e,t,i){function a(e){for(;0>e;)e+=2*o;for(;e>2*o;)e-=2*o;return e}var o=Math.PI;return e=a(e),t=a(t),i=a(i),t>i&&(i+=2*o,e<t&&(e+=2*o)),e>=t&&e<=i}function calRotateTranslate(e,t,i){var a=e,o=i-t,n=a+(i-o-a)/1.4142135623730951;n*=-1;return{transX:n,transY:(i-o)*(1.4142135623730951-1)-(i-o-a)/1.4142135623730951}}function createCurveControlPoints(e,t){function i(e,t){return!!(e[t-1]&&e[t+1])&&(e[t].y>=n(e[t-1].y,e[t+1].y)||e[t].y<=o(e[t-1].y,e[t+1].y))}var o=Math.min,n=Math.max,l=.2,a=.2,r=null,s=null,d=null,h=null;if(1>t?(r=e[0].x+(e[1].x-e[0].x)*l,s=e[0].y+(e[1].y-e[0].y)*l):(r=e[t].x+(e[t+1].x-e[t-1].x)*l,s=e[t].y+(e[t+1].y-e[t-1].y)*l),t>e.length-3){var x=e.length-1;d=e[x].x-(e[x].x-e[x-1].x)*a,h=e[x].y-(e[x].y-e[x-1].y)*a}else d=e[t+1].x-(e[t+2].x-e[t].x)*a,h=e[t+1].y-(e[t+2].y-e[t].y)*a;return i(e,t+1)&&(h=e[t+1].y),i(e,t)&&(s=e[t].y),(s>=n(e[t].y,e[t+1].y)||s<=o(e[t].y,e[t+1].y))&&(s=e[t].y),(h>=n(e[t].y,e[t+1].y)||h<=o(e[t].y,e[t+1].y))&&(h=e[t+1].y),{ctrA:{x:r,y:s},ctrB:{x:d,y:h}}}function convertCoordinateOrigin(e,t,i){return{x:i.x+e,y:i.y-t}}function avoidCollision(e,t){if(t)for(;util.isCollision(e,t);)0<e.start.x?e.start.y--:0>e.start.x?e.start.y++:0<e.start.y?e.start.y++:e.start.y--;return e}function fillSeries(e,t,i){var a=0;return e.map(function(e){if(e.color||(e.color=i.colors[a],a=(a+1)%i.colors.length),e.index||(e.index=0),e.type||(e.type=t.type),"undefined"==typeof e.show&&(e.show=!0),e.type||(e.type=t.type),e.pointShape||(e.pointShape="circle"),!e.legendShape)switch(e.type){case"line":e.legendShape="line";break;case"column":e.legendShape="rect";break;case"area":e.legendShape="triangle";break;default:e.legendShape="circle";}return e})}function getDataRange(e,t){var i=0,a=t-e;return i=1e4<=a?1e3:1e3<=a?100:100<=a?10:10<=a?5:1<=a?1:.1<=a?.1:.01<=a?.01:.001<=a?.001:1e-4<=a?1e-4:1e-5<=a?1e-5:1e-6,{minRange:findRange(e,"lower",i),maxRange:findRange(t,"upper",i)}}function measureText(e){var t=1<arguments.length&&arguments[1]!==void 0?arguments[1]:config.fontSize;e=e+"";var e=e.split(""),a=0;for(let t,o=0;o<e.length;o++)t=e[o],a+=/[a-zA-Z]/.test(t)?7:/[0-9]/.test(t)?5.5:/\./.test(t)?2.7:/-/.test(t)?3.25:/[\u4e00-\u9fa5]/.test(t)?10:/\(|\)/.test(t)?3.73:/\s/.test(t)?2.5:/%/.test(t)?8:10;return a*t/10}function dataCombine(e){return e.reduce(function(e,t){return(e.data?e.data:e).concat(t.data)},[])}function dataCombineStack(e,t){for(var o=Array(t),a=0;a<o.length;a++)o[a]=0;for(var n=0;n<e.length;n++)for(var a=0;a<o.length;a++)o[a]+=e[n].data[a];return e.reduce(function(e,t){return(e.data?e.data:e).concat(t.data).concat(o)},[])}function getTouches(t,i,a){let e,o;return t.clientX?i.rotate?(o=i.height-t.clientX*i.pixelRatio,e=(t.pageY-a.currentTarget.offsetTop-i.height/i.pixelRatio/2*(i.pixelRatio-1))*i.pixelRatio):(e=t.clientX*i.pixelRatio,o=(t.pageY-a.currentTarget.offsetTop-i.height/i.pixelRatio/2*(i.pixelRatio-1))*i.pixelRatio):i.rotate?(o=i.height-t.x*i.pixelRatio,e=t.y*i.pixelRatio):(e=t.x*i.pixelRatio,o=t.y*i.pixelRatio),{x:e,y:o}}function getSeriesDataItem(e,t){var i=[];for(let a,o=0;o<e.length;o++)if(a=e[o],null!==a.data[t]&&"undefined"!=typeof a.data[t]&&a.show){let e={};e.color=a.color,e.type=a.type,e.style=a.style,e.pointShape=a.pointShape,e.disableLegend=a.disableLegend,e.name=a.name,e.show=a.show,e.data=a.format?a.format(a.data[t]):a.data[t],i.push(e)}return i}function getMaxTextListLength(e){var t=e.map(function(e){return measureText(e)});return Math.max.apply(null,t)}function getRadarCoordinateSeries(e){for(var t=Math.PI,a=[],o=0;o<e;o++)a.push(2*t/e*o);return a.map(function(e){return-1*e+t/2})}function getToolTipData(e,t,a,i){var o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:{},n=e.map(function(e){let t=[];return t=i?i:e.data,{text:o.format?o.format(e,t[a]):e.name+": "+e.data,color:e.color}}),l=[],r={x:0,y:0};for(let o,n=0;n<t.length;n++)o=t[n],"undefined"!=typeof o[a]&&null!==o[a]&&l.push(o[a]);for(let o,n=0;n<l.length;n++)o=l[n],r.x=Math.round(o.x),r.y+=o.y;return r.y/=l.length,{textList:n,offset:r}}function getMixToolTipData(e,t,a,i){var o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:{},n=e.map(function(e){return{text:o.format?o.format(e,i[a]):e.name+": "+e.data,color:e.color,disableLegend:!!e.disableLegend}});n=n.filter(function(e){if(!0!==e.disableLegend)return e});var l=[],r={x:0,y:0};for(let o,n=0;n<t.length;n++)o=t[n],"undefined"!=typeof o[a]&&null!==o[a]&&l.push(o[a]);for(let o,n=0;n<l.length;n++)o=l[n],r.x=Math.round(o.x),r.y+=o.y;return r.y/=l.length,{textList:n,offset:r}}function getCandleToolTipData(e,t,a,o,i,n){6<arguments.length&&void 0!==arguments[6]?arguments[6]:{};let l=n.color.upFill,r=n.color.downFill,s=[l,l,r,l];var d=[];let h={text:i[o],color:null};d.push(h),t.map(function(t){0==o&&0>t.data[1]-t.data[0]?s[1]=r:(t.data[0]<e[o-1][1]&&(s[0]=r),t.data[1]<t.data[0]&&(s[1]=r),t.data[2]>e[o-1][1]&&(s[2]=l),t.data[3]<e[o-1][1]&&(s[3]=r));let i={text:"\u5F00\u76D8\uFF1A"+t.data[0],color:s[0]},a={text:"\u6536\u76D8\uFF1A"+t.data[1],color:s[1]},n={text:"\u6700\u4F4E\uFF1A"+t.data[2],color:s[2]},h={text:"\u6700\u9AD8\uFF1A"+t.data[3],color:s[3]};d.push(i,a,n,h)});var x=[],c={x:0,y:0};for(let l,r=0;r<a.length;r++)l=a[r],"undefined"!=typeof l[o]&&null!==l[o]&&x.push(l[o]);return c.x=Math.round(x[0][0].x),{textList:d,offset:c}}function filterSeries(e){let t=[];for(let a=0;a<e.length;a++)!0==e[a].show&&t.push(e[a]);return t}function findCurrentIndex(e,t,i,a){var o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:0,n=-1,l=0;let r=[];for(let o=0;o<t[0].length;o++)r.push(t[0][o].x);return("line"==i.type||"area"==i.type)&&"justify"==i.xAxis.boundaryGap&&(l=i.chartData.eachSpacing/2),i.categories||(l=0),isInExactChartArea(e,i,a)&&r.forEach(function(t,i){e.x+o+l>t&&(n=i)}),n}function findLegendIndex(e,t){let i=-1;if(isInExactLegendArea(e,t.area)){let a=t.points,o=-1;for(let t,n=0,l=a.length;n<l;n++){t=a[n];for(let a=0;a<t.length;a++){o+=1;let n=t[a].area;if(e.x>n[0]&&e.x<n[2]&&e.y>n[1]&&e.y<n[3]){i=o;break}}}return i}return i}function isInExactLegendArea(e,t){return e.x>t.start.x&&e.x<t.end.x&&e.y>t.start.y&&e.y<t.end.y}function isInExactChartArea(e,t){return e.x<=t.width-t.area[1]+10&&e.x>=t.area[3]-10&&e.y>=t.area[0]&&e.y<=t.height-t.area[2]}function findRadarChartCurrentIndex(e,t,i){var a=Math.PI,o=2*a/i,n=-1;if(isInExactPieChartArea(e,t.center,t.radius)){var l=function(e){return 0>e&&(e+=2*a),e>2*a&&(e-=2*a),e},r=Math.atan2(t.center.y-e.y,e.x-t.center.x);r=-1*r,0>r&&(r+=2*a);var s=t.angleList.map(function(e){return e=l(-1*e),e});s.forEach(function(e,t){var i=l(e-o/2),s=l(e+o/2);s<i&&(s+=2*a),(r>=i&&r<=s||r+2*a>=i&&r+2*a<=s)&&(n=t)})}return n}function findFunnelChartCurrentIndex(e,t){for(var a,o=-1,n=0,l=t.series.length;n<l;n++)if(a=t.series[n],e.x>a.funnelArea[0]&&e.x<a.funnelArea[2]&&e.y>a.funnelArea[1]&&e.y<a.funnelArea[3]){o=n;break}return o}function findWordChartCurrentIndex(e,t){for(var a,o=-1,n=0,l=t.length;n<l;n++)if(a=t[n],e.x>a.area[0]&&e.x<a.area[2]&&e.y>a.area[1]&&e.y<a.area[3]){o=n;break}return o}function findMapChartCurrentIndex(e,t){for(var a,o=-1,n=t.chartData.mapData,l=t.series,r=pointToCoordinate(e.y,e.x,n.bounds,n.scale,n.xoffset,n.yoffset),s=[r.x,r.y],d=0,h=l.length;d<h;d++)if(a=l[d].geometry.coordinates,isPoiWithinPoly(s,a)){o=d;break}return o}function findPieChartCurrentIndex(e,t){var a=-1;if(isInExactPieChartArea(e,t.center,t.radius)){var o=Math.atan2(t.center.y-e.y,e.x-t.center.x);o=-o;for(var n,l=0,r=t.series.length;l<r;l++)if(n=t.series[l],isInAngleRange(o,n._start_,n._start_+2*n._proportion_*Math.PI)){a=l;break}}return a}function isInExactPieChartArea(e,t,i){var a=Math.pow;return a(e.x-t.x,2)+a(e.y-t.y,2)<=a(i,2)}function splitPoints(e){var t=[],i=[];return e.forEach(function(e){null===e?(i.length&&t.push(i),i=[]):i.push(e)}),i.length&&t.push(i),t}function calLegendData(e,t,i,a){var o=Math.max,n=Math.floor;let l={area:{start:{x:0,y:0},end:{x:0,y:0},width:0,height:0,wholeWidth:0,wholeHeight:0},points:[],widthArr:[],heightArr:[]};if(!1===t.legend.show)return a.legendData=l,l;let r=t.legend.padding,s=t.legend.margin,d=t.legend.fontSize,h=15*t.pixelRatio,x=5*t.pixelRatio,c=o(t.legend.lineHeight*t.pixelRatio,d);if("top"==t.legend.position||"bottom"==t.legend.position){let a=[],n=0,p=[],g=[];for(let o=0;o<e.length;o++){let i=e[o],l=h+x+measureText(i.name||"undefined",d)+t.legend.itemGap;n+l>t.width-t.padding[1]-t.padding[3]?(a.push(g),p.push(n-t.legend.itemGap),n=l,g=[i]):(n+=l,g.push(i))}if(g.length){a.push(g),p.push(n-t.legend.itemGap),l.widthArr=p;let e=o.apply(null,p);switch(t.legend.float){case"left":l.area.start.x=t.padding[3],l.area.end.x=t.padding[3]+2*r;break;case"right":l.area.start.x=t.width-t.padding[1]-e-2*r,l.area.end.x=t.width-t.padding[1];break;default:l.area.start.x=(t.width-e)/2-r,l.area.end.x=(t.width+e)/2+r;}l.area.width=e+2*r,l.area.wholeWidth=e+2*r,l.area.height=a.length*c+2*r,l.area.wholeHeight=a.length*c+2*r+2*s,l.points=a}}else{let i=e.length,a=t.height-t.padding[0]-t.padding[2]-2*s-2*r,o=Math.min(n(a/c),i);switch(l.area.height=o*c+2*r,l.area.wholeHeight=o*c+2*r,t.legend.float){case"top":l.area.start.y=t.padding[0]+s,l.area.end.y=t.padding[0]+s+l.area.height;break;case"bottom":l.area.start.y=t.height-t.padding[2]-s-l.area.height,l.area.end.y=t.height-t.padding[2]-s;break;default:l.area.start.y=(t.height-l.area.height)/2,l.area.end.y=(t.height+l.area.height)/2;}let p=0==i%o?i/o:n(i/o+1),g=[];for(let t,a=0;a<p;a++)t=e.slice(a*o,a*o+o),g.push(t);if(l.points=g,g.length){for(let e=0;e<g.length;e++){let i=g[e],a=0;for(let e,o=0;o<i.length;o++)e=h+x+measureText(i[o].name||"undefined",d)+t.legend.itemGap,e>a&&(a=e);l.widthArr.push(a),l.heightArr.push(i.length*c+2*r)}let e=0;for(let t=0;t<l.widthArr.length;t++)e+=l.widthArr[t];l.area.width=e-t.legend.itemGap+2*r,l.area.wholeWidth=l.area.width+r}}switch(t.legend.position){case"top":l.area.start.y=t.padding[0]+s,l.area.end.y=t.padding[0]+s+l.area.height;break;case"bottom":l.area.start.y=t.height-t.padding[2]-l.area.height-s,l.area.end.y=t.height-t.padding[2]-s;break;case"left":l.area.start.x=t.padding[3],l.area.end.x=t.padding[3]+l.area.width;break;case"right":l.area.start.x=t.width-t.padding[1]-l.area.width,l.area.end.x=t.width-t.padding[1];}return a.legendData=l,l}function calCategoriesData(e,t,i,a){var o={angle:0,xAxisHeight:i.xAxisHeight},n=e.map(function(e){return measureText(e,t.xAxis.fontSize||i.fontSize)}),l=Math.max.apply(this,n);return!0==t.xAxis.rotateLabel&&l+2*i.xAxisTextPadding>a&&(o.angle=45*Math.PI/180,o.xAxisHeight=2*i.xAxisTextPadding+l*Math.sin(o.angle)),o}function getXAxisTextList(e,t){var a=Math.min,o=Math.max,n=4<arguments.length&&void 0!==arguments[4]?arguments[4]:-1,l=dataCombine(e),r=[];l=l.filter(function(e){return"object"==typeof e&&null!==e?e.constructor==Array?null!==e:null!==e.value:null!==e}),l.map(function(e){"object"==typeof e?e.constructor==Array?"candle"==t.type?e.map(function(e){r.push(e)}):r.push(e[0]):r.push(e.value):r.push(e)});var s=0,d=0;if(0<r.length&&(s=a.apply(this,r),d=o.apply(this,r)),-1<n?("number"==typeof t.xAxis.data[n].min&&(s=a(t.xAxis.data[n].min,s)),"number"==typeof t.xAxis.data[n].max&&(d=o(t.xAxis.data[n].max,d))):("number"==typeof t.xAxis.min&&(s=a(t.xAxis.min,s)),"number"==typeof t.xAxis.max&&(d=o(t.xAxis.max,d))),s===d){var h=d||10;d+=h}for(var x=getDataRange(s,d),c=x.minRange,p=x.maxRange,g=[],y=(p-c)/t.xAxis.splitNumber,f=0;f<=t.xAxis.splitNumber;f++)g.push(c+y*f);return g}function calXAxisData(e,t,i){var a={angle:0,xAxisHeight:i.xAxisHeight};a.ranges=getXAxisTextList(e,t,i),a.rangesFormat=a.ranges.map(function(e){return e=t.xAxis.format?t.xAxis.format(e):util.toFixed(e,2),e});var o=a.ranges.map(function(e){return e=util.toFixed(e,2),e=t.xAxis.format?t.xAxis.format(+e):e,e});a=Object.assign(a,getXAxisPoints(o,t,i));var n=a.eachSpacing,l=o.map(function(e){return measureText(e)}),r=Math.max.apply(this,l);return r+2*i.xAxisTextPadding>n&&(a.angle=45*Math.PI/180,a.xAxisHeight=2*i.xAxisTextPadding+r*Math.sin(a.angle)),!0===t.xAxis.disabled&&(a.xAxisHeight=0),a}function getRadarDataPoints(e,t,i,a,o){var n=Math.max,l=5<arguments.length&&void 0!==arguments[5]?arguments[5]:1,r=o.extra.radar||{};r.max=r.max||0;var s=n(r.max,n.apply(null,dataCombine(a))),d=[];for(let n=0;n<a.length;n++){let o=a[n],r={};r.color=o.color,r.legendShape=o.legendShape,r.pointShape=o.pointShape,r.data=[],o.data.forEach(function(a,o){let n={};n.angle=e[o],n.proportion=a/s,n.position=convertCoordinateOrigin(i*n.proportion*l*Math.cos(n.angle),i*n.proportion*l*Math.sin(n.angle),t),r.data.push(n)}),d.push(r)}return d}function getPieDataPoints(e,t){var a=2<arguments.length&&arguments[2]!==void 0?arguments[2]:1,o=0,n=0;for(let a,n=0;n<e.length;n++)a=e[n],a.data=null===a.data?0:a.data,o+=a.data;for(let n,l=0;l<e.length;l++)n=e[l],n.data=null===n.data?0:n.data,n._proportion_=0===o?1/e.length*a:n.data/o*a,n._radius_=t;for(let a,o=0;o<e.length;o++)a=e[o],a._start_=n,n+=2*a._proportion_*Math.PI;return e}function getFunnelDataPoints(e,t){var a=2<arguments.length&&arguments[2]!==void 0?arguments[2]:1;e=e.sort(function(e,t){return parseInt(t.data)-parseInt(e.data)});for(let o=0;o<e.length;o++)e[o].radius=e[o].data/e[0].data*t*a,e[o]._proportion_=e[o].data/e[0].data;return e.reverse()}function getRoseDataPoints(e,t,a,o){var n=4<arguments.length&&arguments[4]!==void 0?arguments[4]:1,l=0,r=0,s=[];for(let n,r=0;r<e.length;r++)n=e[r],n.data=null===n.data?0:n.data,l+=n.data,s.push(n.data);var d=Math.min.apply(null,s),h=Math.max.apply(null,s);for(let r,s=0;s<e.length;s++)r=e[s],r.data=null===r.data?0:r.data,0===l||"area"==t?(r._proportion_=r.data/l*n,r._rose_proportion_=1/e.length*n):(r._proportion_=r.data/l*n,r._rose_proportion_=r.data/l*n),r._radius_=a+(o-a)*((r.data-d)/(h-d));for(let n,l=0;l<e.length;l++)n=e[l],n._start_=r,r+=2*n._rose_proportion_*Math.PI;return e}function getArcbarDataPoints(e,t){var a=2<arguments.length&&arguments[2]!==void 0?arguments[2]:1;1==a&&(a=.999999);for(let o,n=0;n<e.length;n++){o=e[n],o.data=null===o.data?0:o.data;let i;i="circle"==t.type?2:t.endAngle<t.startAngle?2+t.endAngle-t.startAngle:t.startAngle-t.endAngle,o._proportion_=i*o.data*a+t.startAngle,2<=o._proportion_&&(o._proportion_%=2)}return e}function getGaugeAxisPoints(e,t,a){let o=t;for(let n=0;n<e.length;n++)e[n].value=null===e[n].value?0:e[n].value,e[n]._startAngle_=o,e[n]._endAngle_=(t-a+1)*e[n].value+t,2<=e[n]._endAngle_&&(e[n]._endAngle_%=2),o=e[n]._endAngle_;return e}function getGaugeDataPoints(e,t,a){let o=3<arguments.length&&arguments[3]!==void 0?arguments[3]:1;for(let n,l=0;l<e.length;l++){if(n=e[l],n.data=null===n.data?0:n.data,"auto"==a.pointer.color){for(let e=0;e<t.length;e++)if(n.data<=t[e].value){n.color=t[e].color;break}}else n.color=a.pointer.color;let i=a.startAngle-a.endAngle+1;n._endAngle_=i*n.data+a.startAngle,n._oldAngle_=a.oldAngle,a.oldAngle<a.endAngle&&(n._oldAngle_+=2),n._proportion_=n.data>=a.oldData?(n._endAngle_-n._oldAngle_)*o+a.oldAngle:n._oldAngle_-(n._oldAngle_-n._endAngle_)*o,2<=n._proportion_&&(n._proportion_%=2)}return e}function getPieTextMaxLength(e){e=getPieDataPoints(e);let t=0;for(let a=0;a<e.length;a++){let i=e[a],o=i.format?i.format(+i._proportion_.toFixed(2)):util.toFixed(100*i._proportion_)+"%";t=Math.max(t,measureText(o))}return t}function fixColumeData(e,t,i,a,o,n){return e.map(function(e){return null===e?null:(e.width=Math.ceil((t-2*o.columePadding)/i),n.extra.column&&n.extra.column.width&&0<+n.extra.column.width&&(e.width=Math.min(e.width,+n.extra.column.width)),0>=e.width&&(e.width=1),e.x+=(a+.5-i/2)*e.width,e)})}function fixColumeMeterData(e,t,i,a,o,n,l){return e.map(function(e){return null===e?null:(e.width=Math.ceil((t-2*o.columePadding)/2),n.extra.column&&n.extra.column.width&&0<+n.extra.column.width&&(e.width=Math.min(e.width,+n.extra.column.width)),0<a&&(e.width-=2*l),e)})}function fixColumeStackData(e,t,i,a,o,n){return e.map(function(e){return null===e?null:(e.width=Math.ceil((t-2*o.columePadding)/2),n.extra.column&&n.extra.column.width&&0<+n.extra.column.width&&(e.width=Math.min(e.width,+n.extra.column.width)),e)})}function getXAxisPoints(e,t){var i=t.width-t.area[1]-t.area[3],a=t.enableScroll?Math.min(t.xAxis.itemCount,e.length):e.length;("line"==t.type||"area"==t.type)&&1<a&&"justify"==t.xAxis.boundaryGap&&(a-=1);var o=i/a,n=[],l=t.area[3],r=t.width-t.area[1];return e.forEach(function(e,t){n.push(l+t*o)}),"justify"!==t.xAxis.boundaryGap&&(!0===t.enableScroll?n.push(l+e.length*o):n.push(r)),{xAxisPoints:n,startX:l,endX:r,eachSpacing:o}}function getCandleDataPoints(e,t,i,a,o,n){var l=Math.round,r=7<arguments.length&&void 0!==arguments[7]?arguments[7]:1,s=[],d=n.height-n.area[0]-n.area[2];return e.forEach(function(e,h){if(null===e)s.push(null);else{var x=[];e.forEach(function(e){var s={x:a[h]+l(o/2)},c=e.value||e,p=d*(c-t)/(i-t);p*=r,s.y=n.height-l(p)-n.area[2],x.push(s)}),s.push(x)}}),s}function getDataPoints(e,t,i,a,o,n){var l=Math.round,r=7<arguments.length&&void 0!==arguments[7]?arguments[7]:1,s="center";("line"==n.type||"area"==n.type)&&(s=n.xAxis.boundaryGap);var d=[],h=n.height-n.area[0]-n.area[2],x=n.width-n.area[1]-n.area[3];return e.forEach(function(e,c){if(null===e)d.push(null);else{var p={color:e.color,x:a[c]},g=e;if("object"==typeof e&&null!==e)if(e.constructor==Array){let t,i,a;t=[].concat(n.chartData.xAxisData.ranges),i=t.shift(),a=t.pop(),g=e[1],p.x=n.area[3]+x*(e[0]-i)/(a-i)}else g=e.value;"center"==s&&(p.x+=l(o/2));var y=h*(g-t)/(i-t);y*=r,p.y=n.height-l(y)-n.area[2],d.push(p)}}),d}function getStackDataPoints(e,t,i,a,o,n,l,r,s){var d=Math.round,h=9<arguments.length&&void 0!==arguments[9]?arguments[9]:1,x=[],c=n.height-n.area[0]-n.area[2];return e.forEach(function(e,l){if(null===e)x.push(null);else{var p={color:e.color,x:a[l]+d(o/2)};if(0<r){var g=0;for(let e=0;e<=r;e++)g+=s[e].data[l];var y=g-e,f=c*(g-t)/(i-t),u=c*(y-t)/(i-t)}else var g=e,f=c*(g-t)/(i-t),u=0;var m=u;f*=h,m*=h,p.y=n.height-d(f)-n.area[2],p.y0=n.height-d(m)-n.area[2],x.push(p)}}),x}function getYAxisTextList(e,t,a,o){var n,l=Math.min,r=Math.max,s=4<arguments.length&&void 0!==arguments[4]?arguments[4]:-1;n="stack"==o?dataCombineStack(e,t.categories.length):dataCombine(e);var d=[];n=n.filter(function(e){return"object"==typeof e&&null!==e?e.constructor==Array?null!==e:null!==e.value:null!==e}),n.map(function(e){"object"==typeof e?e.constructor==Array?"candle"==t.type?e.map(function(e){d.push(e)}):d.push(e[1]):d.push(e.value):d.push(e)});var h=0,x=0;if(0<d.length&&(h=l.apply(this,d),x=r.apply(this,d)),-1<s?("number"==typeof t.yAxis.data[s].min&&(h=l(t.yAxis.data[s].min,h)),"number"==typeof t.yAxis.data[s].max&&(x=r(t.yAxis.data[s].max,x))):("number"==typeof t.yAxis.min&&(h=l(t.yAxis.min,h)),"number"==typeof t.yAxis.max&&(x=r(t.yAxis.max,x))),h===x){var c=x||10;x+=c}for(var p=getDataRange(h,x),g=p.minRange,y=p.maxRange,f=[],u=(y-g)/t.yAxis.splitNumber,m=0;m<=t.yAxis.splitNumber;m++)f.push(g+u*m);return f.reverse()}function calYAxisData(e,t,a){var o=Math.max,n=assign({},{type:""},t.extra.column),l=t.yAxis.data.length,r=Array(l);if(0<l){for(let t=0;t<l;t++){r[t]=[];for(let i=0;i<e.length;i++)e[i].index==t&&r[t].push(e[i])}var s=Array(l),d=Array(l),h=Array(l);for(let e,x=0;x<l;x++){e=t.yAxis.data[x],!0==t.yAxis.disabled&&(e.disabled=!0),s[x]=getYAxisTextList(r[x],t,a,n.type,x);let i=e.fontSize||a.fontSize;h[x]={position:e.position?e.position:"left",width:0},d[x]=s[x].map(function(t){return t=util.toFixed(t,6),t=e.format?e.format(+t):t,h[x].width=o(h[x].width,measureText(t,i)+5),t});let l=e.calibration?4*t.pixelRatio:0;h[x].width+=l+3*t.pixelRatio,!0===e.disabled&&(h[x].width=0)}}else{var s=[,],d=[,],h=[,];s[0]=getYAxisTextList(e,t,a,n.type),h[0]={position:"left",width:0};var i=t.yAxis.fontSize||a.fontSize;d[0]=s[0].map(function(e){return e=util.toFixed(e,6),e=t.yAxis.format?t.yAxis.format(+e):e,h[0].width=o(h[0].width,measureText(e,i)+5),e}),h[0].width+=3*t.pixelRatio,!0===t.yAxis.disabled?(h[0]={position:"left",width:0},t.yAxis.data[0]={disabled:!0}):t.yAxis.data[0]={disabled:!1,position:"left",max:t.yAxis.max,min:t.yAxis.min,format:t.yAxis.format}}return{rangesFormat:d,ranges:s,yAxisWidth:h}}function calTooltipYAxisData(e,t,a){let o=[].concat(a.chartData.yAxisData.ranges),n=a.height-a.area[0]-a.area[2],l=a.area[0],r=[];for(let s=0;s<o.length;s++){let t=o[s].shift(),i=o[s].pop(),d=t-(t-i)*(e-l)/n;d=a.yAxis.data[s].format?a.yAxis.data[s].format(+d):d.toFixed(0),r.push(d+"")}return r}function calMarkLineData(e,t){let a,o,n=t.height-t.area[0]-t.area[2];for(let l=0;l<e.length;l++){e[l].yAxisIndex=e[l].yAxisIndex?e[l].yAxisIndex:0;let i=[].concat(t.chartData.yAxisData.ranges[e[l].yAxisIndex]);a=i.pop(),o=i.shift();let r=n*(e[l].value-a)/(o-a);e[l].y=t.height-Math.round(r)-t.area[2]}return e}function contextRotate(e,t){var i=Math.PI;!0===t.rotateLock?!0!==t._rotate_&&(e.translate(t.height,0),e.rotate(90*i/180),t._rotate_=!0):(e.translate(t.height,0),e.rotate(90*i/180))}function drawPointShape(e,t,i,a,o){a.beginPath(),"hollow"==o.dataPointShapeType?(a.setStrokeStyle(t),a.setFillStyle(o.background),a.setLineWidth(2*o.pixelRatio)):(a.setStrokeStyle("#ffffff"),a.setFillStyle(t),a.setLineWidth(1*o.pixelRatio)),"diamond"===i?e.forEach(function(e){null!==e&&(a.moveTo(e.x,e.y-4.5),a.lineTo(e.x-4.5,e.y),a.lineTo(e.x,e.y+4.5),a.lineTo(e.x+4.5,e.y),a.lineTo(e.x,e.y-4.5))}):"circle"===i?e.forEach(function(e){null!==e&&(a.moveTo(e.x+2.5*o.pixelRatio,e.y),a.arc(e.x,e.y,3*o.pixelRatio,0,2*Math.PI,!1))}):"rect"===i?e.forEach(function(e){null!==e&&(a.moveTo(e.x-3.5,e.y-3.5),a.rect(e.x-3.5,e.y-3.5,7,7))}):"triangle"==i&&e.forEach(function(e){null!==e&&(a.moveTo(e.x,e.y-4.5),a.lineTo(e.x-4.5,e.y+4.5),a.lineTo(e.x+4.5,e.y+4.5),a.lineTo(e.x,e.y-4.5))}),a.closePath(),a.fill(),a.stroke()}function drawRingTitle(e,t,i,a){var o=e.title.fontSize||t.titleFontSize,n=e.subtitle.fontSize||t.subtitleFontSize,l=e.title.name||"",r=e.subtitle.name||"",s=e.title.color||t.titleColor,d=e.subtitle.color||t.subtitleColor,h=l?o:0,x=r?n:0,c=5;if(r){var p=measureText(r,n),g=a.x-p/2+(e.subtitle.offsetX||0),y=a.y+n/2+(e.subtitle.offsetY||0);l&&(y+=(h+c)/2),i.beginPath(),i.setFontSize(n),i.setFillStyle(d),i.fillText(r,g,y),i.closePath(),i.stroke()}if(l){var f=measureText(l,o),u=a.x-f/2+(e.title.offsetX||0),m=a.y+o/2+(e.title.offsetY||0);r&&(m-=(x+c)/2),i.beginPath(),i.setFontSize(o),i.setFillStyle(s),i.fillText(l,u,m),i.closePath(),i.stroke()}}function drawPointText(e,t,i,a){var o=t.data;e.forEach(function(e,n){if(null!==e){a.beginPath(),a.setFontSize(t.textSize||i.fontSize),a.setFillStyle(t.textColor||"#666666");var l=o[n];"object"==typeof o[n]&&null!==o[n]&&(o[n].constructor==Array?l=o[n][1]:l=o[n].value);var r=t.format?t.format(l):l;a.fillText(r+"",e.x-measureText(r,t.textSize||i.fontSize)/2,e.y-4),a.closePath(),a.stroke()}})}function drawGaugeLabel(e,t,i,a,o,n){var l=Math.PI;t-=e.width/2+o.gaugeLabelTextMargin;let r=e.startAngle-e.endAngle+1,s=r/e.splitLine.splitNumber,d=e.endNumber-e.startNumber,h=d/e.splitLine.splitNumber,x=e.startAngle,c=e.startNumber;for(let r=0;r<e.splitLine.splitNumber+1;r++){var p={x:t*Math.cos(x*l),y:t*Math.sin(x*l)},g=e.labelFormat?e.labelFormat(c):c;p.x+=i.x-measureText(g)/2,p.y+=i.y;var y=p.x,f=p.y;n.beginPath(),n.setFontSize(o.fontSize),n.setFillStyle(e.labelColor||"#666666"),n.fillText(g,y,f+o.fontSize/2),n.closePath(),n.stroke(),x+=s,2<=x&&(x%=2),c+=h}}function drawRadarLabel(e,t,i,a,o,n){var l=a.extra.radar||{};t+=o.radarLabelTextMargin,e.forEach(function(e,r){var s={x:t*Math.cos(e),y:t*Math.sin(e)},d=convertCoordinateOrigin(s.x,s.y,i),h=d.x,x=d.y;util.approximatelyEqual(s.x,0)?h-=measureText(a.categories[r]||"")/2:0>s.x&&(h-=measureText(a.categories[r]||"")),n.beginPath(),n.setFontSize(o.fontSize),n.setFillStyle(l.labelColor||"#666666"),n.fillText(a.categories[r]||"",h,x+o.fontSize/2),n.closePath(),n.stroke()})}function drawPieText(e,t,a,o,i,n){var l=Math.cos,r=Math.sin,s=Math.min,d=Math.max,h=Math.PI,x=a.pieChartLinePadding,c=[],p=null,g=e.map(function(e){var t=e.format?e.format(+e._proportion_.toFixed(2)):util.toFixed(100*e._proportion_.toFixed(4))+"%";e._rose_proportion_&&(e._proportion_=e._rose_proportion_);var i=2*h-(e._start_+2*h*e._proportion_/2),a=e.color,o=e._radius_;return{arc:i,text:t,color:a,radius:o,textColor:e.textColor,textSize:e.textSize}});for(let h=0;h<g.length;h++){let e=g[h],t=l(e.arc)*(e.radius+x),i=r(e.arc)*(e.radius+x),o=l(e.arc)*e.radius,n=r(e.arc)*e.radius,y=0<=t?t+a.pieChartTextPadding:t-a.pieChartTextPadding,f=i,u=measureText(e.text,e.textSize||a.fontSize),m=f;p&&util.isSameXCoordinateArea(p.start,{x:y})&&(0<y?m=s(f,p.start.y):0>t?m=d(f,p.start.y):0<f?m=d(f,p.start.y):m=s(f,p.start.y)),0>y&&(y-=u);let S={lineStart:{x:o,y:n},lineEnd:{x:t,y:i},start:{x:y,y:m},width:u,height:a.fontSize,text:e.text,color:e.color,textColor:e.textColor,textSize:e.textSize};p=avoidCollision(S,p),c.push(p)}for(let l=0;l<c.length;l++){let e=c[l],i=convertCoordinateOrigin(e.lineStart.x,e.lineStart.y,n),r=convertCoordinateOrigin(e.lineEnd.x,e.lineEnd.y,n),s=convertCoordinateOrigin(e.start.x,e.start.y,n);o.setLineWidth(1*t.pixelRatio),o.setFontSize(a.fontSize),o.beginPath(),o.setStrokeStyle(e.color),o.setFillStyle(e.color),o.moveTo(i.x,i.y);let d=0>e.start.x?s.x+e.width:s.x,x=0>e.start.x?s.x-5:s.x+5;o.quadraticCurveTo(r.x,r.y,d,s.y),o.moveTo(i.x,i.y),o.stroke(),o.closePath(),o.beginPath(),o.moveTo(s.x+e.width,s.y),o.arc(d,s.y,2,0,2*h),o.closePath(),o.fill(),o.beginPath(),o.setFontSize(e.textSize||a.fontSize),o.setFillStyle(e.textColor||"#666666"),o.fillText(e.text,x,s.y+3),o.closePath(),o.stroke(),o.closePath()}}function drawToolTipSplitLine(e,t,i,a){var o=t.extra.tooltip||{};o.gridType=null==o.gridType?"solid":o.gridType,o.dashLength=null==o.dashLength?4:o.dashLength;var n=t.area[0],l=t.height-t.area[2];if("dash"==o.gridType&&a.setLineDash([o.dashLength,o.dashLength]),a.setStrokeStyle(o.gridColor||"#cccccc"),a.setLineWidth(1*t.pixelRatio),a.beginPath(),a.moveTo(e,n),a.lineTo(e,l),a.stroke(),a.setLineDash([]),o.xAxisLabel){let n=t.categories[t.tooltip.index];a.setFontSize(i.fontSize);let r=measureText(n,i.fontSize),s=e-.5*r,d=l;a.beginPath(),a.setFillStyle(hexToRgb(o.labelBgColor||i.toolTipBackground,o.labelBgOpacity||i.toolTipOpacity)),a.setStrokeStyle(o.labelBgColor||i.toolTipBackground),a.setLineWidth(1*t.pixelRatio),a.rect(s-i.toolTipPadding,d,r+2*i.toolTipPadding,i.fontSize+2*i.toolTipPadding),a.closePath(),a.stroke(),a.fill(),a.beginPath(),a.setFontSize(i.fontSize),a.setFillStyle(o.labelFontColor||i.fontColor),a.fillText(n+"",s,d+i.toolTipPadding+i.fontSize),a.closePath(),a.stroke()}}function drawMarkLine(e,t,a){let o=assign({},{type:"solid",dashLength:4,data:[]},e.extra.markLine),n=e.area[3],l=e.width-e.area[1],r=calMarkLineData(o.data,e);for(let s,d=0;d<r.length;d++)if(s=assign({},{lineColor:"#DE4A42",showLabel:!1,labelFontColor:"#666666",labelBgColor:"#DFE8FF",labelBgOpacity:.8,yAxisIndex:0},r[d]),"dash"==o.type&&a.setLineDash([o.dashLength,o.dashLength]),a.setStrokeStyle(s.lineColor),a.setLineWidth(1*e.pixelRatio),a.beginPath(),a.moveTo(n,s.y),a.lineTo(l,s.y),a.stroke(),a.setLineDash([]),s.showLabel){let i=e.yAxis.format?e.yAxis.format(+s.value):s.value;a.setFontSize(t.fontSize);let o=measureText(i,t.fontSize),n=e.padding[3]+t.yAxisTitleWidth-t.toolTipPadding,l=Math.max(e.area[3],o+2*t.toolTipPadding),r=l-n,d=s.y;a.setFillStyle(hexToRgb(s.labelBgColor,s.labelBgOpacity)),a.setStrokeStyle(s.labelBgColor),a.setLineWidth(1*e.pixelRatio),a.beginPath(),a.rect(n,d-.5*t.fontSize-t.toolTipPadding,r,t.fontSize+2*t.toolTipPadding),a.closePath(),a.stroke(),a.fill(),a.beginPath(),a.setFontSize(t.fontSize),a.setFillStyle(s.labelFontColor),a.fillText(i+"",n+(r-o)/2,d+.5*t.fontSize),a.stroke()}}function drawToolTipHorizentalLine(e,t,a,i){var o=Math.max,n=assign({},{gridType:"solid",dashLength:4},e.extra.tooltip),l=e.area[3],r=e.width-e.area[1];if("dash"==n.gridType&&a.setLineDash([n.dashLength,n.dashLength]),a.setStrokeStyle(n.gridColor||"#cccccc"),a.setLineWidth(1*e.pixelRatio),a.beginPath(),a.moveTo(l,e.tooltip.offset.y),a.lineTo(r,e.tooltip.offset.y),a.stroke(),a.setLineDash([]),n.yAxisLabel){let l=calTooltipYAxisData(e.tooltip.offset.y,e.series,e,t,i),r=e.chartData.yAxisData.yAxisWidth,s=e.area[3],d=e.width-e.area[1];for(let h=0;h<l.length;h++){a.setFontSize(t.fontSize);let i,x,c,p=measureText(l[h],t.fontSize);"left"==r[h].position?(i=s-r[h].width,x=o(i,i+p+2*t.toolTipPadding)):(i=d,x=o(i+r[h].width,i+p+2*t.toolTipPadding)),c=x-i;let g=i+(c-p)/2,y=e.tooltip.offset.y;a.beginPath(),a.setFillStyle(hexToRgb(n.labelBgColor||t.toolTipBackground,n.labelBgOpacity||t.toolTipOpacity)),a.setStrokeStyle(n.labelBgColor||t.toolTipBackground),a.setLineWidth(1*e.pixelRatio),a.rect(i,y-.5*t.fontSize-t.toolTipPadding,c,t.fontSize+2*t.toolTipPadding),a.closePath(),a.stroke(),a.fill(),a.beginPath(),a.setFontSize(t.fontSize),a.setFillStyle(n.labelFontColor||t.fontColor),a.fillText(l[h],g,y+.5*t.fontSize),a.closePath(),a.stroke(),"left"==r[h].position?s-=r[h].width+e.yAxis.padding:d+=r[h].width+e.yAxis.padding}}}function drawToolTipSplitArea(e,t,i,a,o){var n=assign({},{activeBgColor:"#000000",activeBgOpacity:.08},t.extra.tooltip),l=t.area[0],r=t.height-t.area[2];a.beginPath(),a.setFillStyle(hexToRgb(n.activeBgColor,n.activeBgOpacity)),a.rect(e-o/2,l,o,r-l),a.closePath(),a.fill()}function drawToolTip(e,t,i,a,o){var n=Math.round,l=assign({},{showBox:!0,bgColor:"#000000",bgOpacity:.7,fontColor:"#FFFFFF"},i.extra.tooltip),r=4*i.pixelRatio,s=5*i.pixelRatio,d=8*i.pixelRatio,h=!1;("line"==i.type||"area"==i.type||"candle"==i.type||"mix"==i.type)&&drawToolTipSplitLine(i.tooltip.offset.x,i,a,o),t=assign({x:0,y:0},t),t.y-=8*i.pixelRatio;var x=e.map(function(e){return measureText(e.text,a.fontSize)}),c=r+s+4*a.toolTipPadding+Math.max.apply(null,x),p=2*a.toolTipPadding+e.length*a.toolTipLineHeight;!1==l.showBox||(t.x-Math.abs(i._scrollDistance_)+d+c>i.width&&(h=!0),p+t.y>i.height&&(t.y=i.height-p),o.beginPath(),o.setFillStyle(hexToRgb(l.bgColor||a.toolTipBackground,l.bgOpacity||a.toolTipOpacity)),h?(o.moveTo(t.x,t.y+10*i.pixelRatio),o.lineTo(t.x-d,t.y+10*i.pixelRatio-5*i.pixelRatio),o.lineTo(t.x-d,t.y),o.lineTo(t.x-d-n(c),t.y),o.lineTo(t.x-d-n(c),t.y+p),o.lineTo(t.x-d,t.y+p),o.lineTo(t.x-d,t.y+10*i.pixelRatio+5*i.pixelRatio),o.lineTo(t.x,t.y+10*i.pixelRatio)):(o.moveTo(t.x,t.y+10*i.pixelRatio),o.lineTo(t.x+d,t.y+10*i.pixelRatio-5*i.pixelRatio),o.lineTo(t.x+d,t.y),o.lineTo(t.x+d+n(c),t.y),o.lineTo(t.x+d+n(c),t.y+p),o.lineTo(t.x+d,t.y+p),o.lineTo(t.x+d,t.y+10*i.pixelRatio+5*i.pixelRatio),o.lineTo(t.x,t.y+10*i.pixelRatio)),o.closePath(),o.fill(),e.forEach(function(e,i){if(null!==e.color){o.beginPath(),o.setFillStyle(e.color);var n=t.x+d+2*a.toolTipPadding,l=t.y+(a.toolTipLineHeight-a.fontSize)/2+a.toolTipLineHeight*i+a.toolTipPadding+1;h&&(n=t.x-c-d+2*a.toolTipPadding),o.fillRect(n,l,r,a.fontSize),o.closePath()}}),e.forEach(function(e,i){var n=t.x+d+2*a.toolTipPadding+r+s;h&&(n=t.x-c-d+2*a.toolTipPadding+ +r+s);var x=t.y+(a.toolTipLineHeight-a.fontSize)/2+a.toolTipLineHeight*i+a.toolTipPadding;o.beginPath(),o.setFontSize(a.fontSize),o.setFillStyle(l.fontColor),o.fillText(e.text,n,x+a.fontSize),o.closePath(),o.stroke()}))}function drawYAxisTitle(e,t,i,a){var o=i.xAxisHeight+(t.height-i.xAxisHeight-measureText(e))/2;a.save(),a.beginPath(),a.setFontSize(i.fontSize),a.setFillStyle(t.yAxis.titleFontColor||"#333333"),a.translate(0,t.height),a.rotate(-90*Math.PI/180),a.fillText(e,o,t.padding[3]+.5*i.fontSize),a.closePath(),a.stroke(),a.restore()}function drawColumnDataPoints(e,t,i,a){let o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,n=t.chartData.xAxisData,l=n.xAxisPoints,r=n.eachSpacing,s=assign({},{type:"group",width:r/2,meter:{border:4,fillColor:"#FFFFFF"}},t.extra.column),d=[];a.save();let h=-2,x=l.length+2;return t._scrollDistance_&&0!==t._scrollDistance_&&!0===t.enableScroll&&(a.translate(t._scrollDistance_,0),h=Math.floor(-t._scrollDistance_/r)-2,x=h+t.xAxis.itemCount+4),t.tooltip&&t.tooltip.textList&&t.tooltip.textList.length&&1===o&&drawToolTipSplitArea(t.tooltip.offset.x,t,i,a,r),e.forEach(function(n,c){let p,g,y;p=[].concat(t.chartData.yAxisData.ranges[n.index]),g=p.pop(),y=p.shift();var f=n.data;switch(s.type){case"group":var u=getDataPoints(f,g,y,l,r,t,i,o),m=getStackDataPoints(f,g,y,l,r,t,i,c,e,o);d.push(m),u=fixColumeData(u,r,e.length,c,i,t);for(let e,o=0;o<u.length;o++)if(e=u[o],null!==e&&o>h&&o<x){a.beginPath(),a.setStrokeStyle(e.color||n.color),a.setLineWidth(1),a.setFillStyle(e.color||n.color);var S=e.x-e.width/2,T=t.height-e.y-t.area[2];a.moveTo(S-1,e.y),a.lineTo(S+e.width-2,e.y),a.lineTo(S+e.width-2,t.height-t.area[2]),a.lineTo(S,t.height-t.area[2]),a.lineTo(S,e.y),a.closePath(),a.stroke(),a.fill()};break;case"stack":var u=getStackDataPoints(f,g,y,l,r,t,i,c,e,o);d.push(u),u=fixColumeStackData(u,r,e.length,c,i,t,e);for(let e,o=0;o<u.length;o++)if(e=u[o],null!==e&&o>h&&o<x){a.beginPath(),a.setFillStyle(e.color||n.color);var S=e.x-e.width/2+1,T=t.height-e.y-t.area[2],A=t.height-e.y0-t.area[2];0<c&&(T-=A),a.moveTo(S,e.y),a.fillRect(S,e.y,e.width-2,T),a.closePath(),a.fill()};break;case"meter":var u=getDataPoints(f,g,y,l,r,t,i,o);if(d.push(u),u=fixColumeMeterData(u,r,e.length,c,i,t,s.meter.border),0==c){for(let e,o=0;o<u.length;o++)if(e=u[o],null!==e&&o>h&&o<x){a.beginPath(),a.setFillStyle(s.meter.fillColor);var S=e.x-e.width/2,T=t.height-e.y-t.area[2];a.moveTo(S,e.y),a.fillRect(S,e.y,e.width,T),a.closePath(),a.fill(),0<s.meter.border&&(a.beginPath(),a.setStrokeStyle(n.color),a.setLineWidth(s.meter.border*t.pixelRatio),a.moveTo(S+.5*s.meter.border,e.y+T),a.lineTo(S+.5*s.meter.border,e.y+.5*s.meter.border),a.lineTo(S+e.width-.5*s.meter.border,e.y+.5*s.meter.border),a.lineTo(S+e.width-.5*s.meter.border,e.y+T),a.stroke())}}else for(let e,o=0;o<u.length;o++)if(e=u[o],null!==e&&o>h&&o<x){a.beginPath(),a.setFillStyle(e.color||n.color);var S=e.x-e.width/2,T=t.height-e.y-t.area[2];a.moveTo(S,e.y),a.fillRect(S,e.y,e.width,T),a.closePath(),a.fill()}}}),!1!==t.dataLabel&&1===o&&e.forEach(function(n,d){let h,x,c;h=[].concat(t.chartData.yAxisData.ranges[n.index]),x=h.pop(),c=h.shift();var p=n.data;switch(s.type){case"group":var g=getDataPoints(p,x,c,l,r,t,i,o);g=fixColumeData(g,r,e.length,d,i,t),drawPointText(g,n,i,a);break;case"stack":var g=getStackDataPoints(p,x,c,l,r,t,i,d,e,o);drawPointText(g,n,i,a);break;case"meter":var g=getDataPoints(p,x,c,l,r,t,i,o);drawPointText(g,n,i,a);}}),a.restore(),{xAxisPoints:l,calPoints:d,eachSpacing:r}}function drawCandleDataPoints(e,t,a,i,o){var n=5<arguments.length&&void 0!==arguments[5]?arguments[5]:1,l=assign({},{color:{},average:{}},a.extra.candle);l.color=assign({},{upLine:"#f04864",upFill:"#f04864",downLine:"#2fc25b",downFill:"#2fc25b"},l.color),l.average=assign({},{show:!1,name:[],day:[],color:i.colors},l.average),a.extra.candle=l;let r=a.chartData.xAxisData,s=r.xAxisPoints,d=r.eachSpacing,h=[];o.save();let x=-2,c=s.length+2,p=0,g=a.width+d;return a._scrollDistance_&&0!==a._scrollDistance_&&!0===a.enableScroll&&(o.translate(a._scrollDistance_,0),x=Math.floor(-a._scrollDistance_/d)-2,c=x+a.xAxis.itemCount+4,p=-a._scrollDistance_-d+a.area[3],g=p+(a.xAxis.itemCount+4)*d),l.average.show&&t.forEach(function(e){let t,l,r;t=[].concat(a.chartData.yAxisData.ranges[e.index]),l=t.pop(),r=t.shift();var h=e.data,x=getDataPoints(h,l,r,s,d,a,i,n),c=splitPoints(x);for(let t,a=0;a<c.length;a++){if(t=c[a],o.beginPath(),o.setStrokeStyle(e.color),o.setLineWidth(1),1===t.length)o.moveTo(t[0].x,t[0].y),o.arc(t[0].x,t[0].y,1,0,2*Math.PI);else{o.moveTo(t[0].x,t[0].y);let e=0;for(let i,a=0;a<t.length;a++)if(i=t[a],0==e&&i.x>p&&(o.moveTo(i.x,i.y),e=1),0<a&&i.x>p&&i.x<g){var y=createCurveControlPoints(t,a-1);o.bezierCurveTo(y.ctrA.x,y.ctrA.y,y.ctrB.x,y.ctrB.y,i.x,i.y)}o.moveTo(t[0].x,t[0].y)}o.closePath(),o.stroke()}}),e.forEach(function(e){let t,r,p;t=[].concat(a.chartData.yAxisData.ranges[e.index]),r=t.pop(),p=t.shift();var g=e.data,y=getCandleDataPoints(g,r,p,s,d,a,i,n);h.push(y);var f=splitPoints(y);for(let t=0;t<f[0].length;t++)if(t>x&&t<c){let e=f[0][t];o.beginPath(),0<g[t][1]-g[t][0]?(o.setStrokeStyle(l.color.upLine),o.setFillStyle(l.color.upFill),o.setLineWidth(1*a.pixelRatio),o.moveTo(e[3].x,e[3].y),o.lineTo(e[1].x,e[1].y),o.lineTo(e[1].x-d/4,e[1].y),o.lineTo(e[0].x-d/4,e[0].y),o.lineTo(e[0].x,e[0].y),o.lineTo(e[2].x,e[2].y),o.lineTo(e[0].x,e[0].y),o.lineTo(e[0].x+d/4,e[0].y),o.lineTo(e[1].x+d/4,e[1].y),o.lineTo(e[1].x,e[1].y),o.moveTo(e[3].x,e[3].y)):(o.setStrokeStyle(l.color.downLine),o.setFillStyle(l.color.downFill),o.setLineWidth(1*a.pixelRatio),o.moveTo(e[3].x,e[3].y),o.lineTo(e[0].x,e[0].y),o.lineTo(e[0].x-d/4,e[0].y),o.lineTo(e[1].x-d/4,e[1].y),o.lineTo(e[1].x,e[1].y),o.lineTo(e[2].x,e[2].y),o.lineTo(e[1].x,e[1].y),o.lineTo(e[1].x+d/4,e[1].y),o.lineTo(e[0].x+d/4,e[0].y),o.lineTo(e[0].x,e[0].y),o.moveTo(e[3].x,e[3].y)),o.closePath(),o.fill(),o.stroke()}}),o.restore(),{xAxisPoints:s,calPoints:h,eachSpacing:d}}function drawAreaDataPoints(e,t,i,a){var o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,n=assign({},{type:"straight",opacity:.2,addLine:!1,width:2,gradient:!1},t.extra.area);let l=t.chartData.xAxisData,r=l.xAxisPoints,s=l.eachSpacing,d=t.height-t.area[2],h=[];a.save();let x=0,c=t.width+s;return t._scrollDistance_&&0!==t._scrollDistance_&&!0===t.enableScroll&&(a.translate(t._scrollDistance_,0),x=-t._scrollDistance_-s+t.area[3],c=x+(t.xAxis.itemCount+4)*s),e.forEach(function(e){let l,p,g;l=[].concat(t.chartData.yAxisData.ranges[e.index]),p=l.pop(),g=l.shift();let y=e.data,f=getDataPoints(y,p,g,r,s,t,i,o);h.push(f);let u=splitPoints(f);for(let o,l=0;l<u.length;l++){if(o=u[l],a.beginPath(),a.setStrokeStyle(hexToRgb(e.color,n.opacity)),n.gradient){let i=a.createLinearGradient(0,t.area[0],0,t.height-t.area[2]);i.addColorStop("0",hexToRgb(e.color,n.opacity)),i.addColorStop("1.0",hexToRgb("#FFFFFF",.1)),a.setFillStyle(i)}else a.setFillStyle(hexToRgb(e.color,n.opacity));if(a.setLineWidth(n.width*t.pixelRatio),1<o.length){let e=o[0],t=o[o.length-1];a.moveTo(e.x,e.y);let i=0;if("curve"===n.type){for(let e,t=0;t<o.length;t++)if(e=o[t],0==i&&e.x>x&&(a.moveTo(e.x,e.y),i=1),0<t&&e.x>x&&e.x<c){let i=createCurveControlPoints(o,t-1);a.bezierCurveTo(i.ctrA.x,i.ctrA.y,i.ctrB.x,i.ctrB.y,e.x,e.y)}}else for(let e,t=0;t<o.length;t++)e=o[t],0==i&&e.x>x&&(a.moveTo(e.x,e.y),i=1),0<t&&e.x>x&&e.x<c&&a.lineTo(e.x,e.y);a.lineTo(t.x,d),a.lineTo(e.x,d),a.lineTo(e.x,e.y)}else{let e=o[0];a.moveTo(e.x-s/2,e.y),a.lineTo(e.x+s/2,e.y),a.lineTo(e.x+s/2,d),a.lineTo(e.x-s/2,d),a.moveTo(e.x-s/2,e.y)}if(a.closePath(),a.fill(),n.addLine){if("dash"==e.lineType){let i=e.dashLength?e.dashLength:8;i*=t.pixelRatio,a.setLineDash([i,i])}if(a.beginPath(),a.setStrokeStyle(e.color),a.setLineWidth(n.width*t.pixelRatio),1===o.length)a.moveTo(o[0].x,o[0].y),a.arc(o[0].x,o[0].y,1,0,2*Math.PI);else{a.moveTo(o[0].x,o[0].y);let e=0;if("curve"===n.type){for(let t,i=0;i<o.length;i++)if(t=o[i],0==e&&t.x>x&&(a.moveTo(t.x,t.y),e=1),0<i&&t.x>x&&t.x<c){let e=createCurveControlPoints(o,i-1);a.bezierCurveTo(e.ctrA.x,e.ctrA.y,e.ctrB.x,e.ctrB.y,t.x,t.y)}}else for(let t,i=0;i<o.length;i++)t=o[i],0==e&&t.x>x&&(a.moveTo(t.x,t.y),e=1),0<i&&t.x>x&&t.x<c&&a.lineTo(t.x,t.y);a.moveTo(o[0].x,o[0].y)}a.stroke(),a.setLineDash([])}}!1!==t.dataPointShape&&drawPointShape(f,e.color,e.pointShape,a,t)}),!1!==t.dataLabel&&1===o&&e.forEach(function(e){let n,l,d;n=[].concat(t.chartData.yAxisData.ranges[e.index]),l=n.pop(),d=n.shift();var h=e.data,x=getDataPoints(h,l,d,r,s,t,i,o);drawPointText(x,e,i,a)}),a.restore(),{xAxisPoints:r,calPoints:h,eachSpacing:s}}function drawLineDataPoints(e,t,i,a){var o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,n=assign({},{type:"straight",width:2},t.extra.line);n.width*=t.pixelRatio;let l=t.chartData.xAxisData,r=l.xAxisPoints,s=l.eachSpacing;var d=[];a.save();let h=0,x=t.width+s;return t._scrollDistance_&&0!==t._scrollDistance_&&!0===t.enableScroll&&(a.translate(t._scrollDistance_,0),h=-t._scrollDistance_-s+t.area[3],x=h+(t.xAxis.itemCount+4)*s),e.forEach(function(e){let l,c,p;l=[].concat(t.chartData.yAxisData.ranges[e.index]),c=l.pop(),p=l.shift();var g=e.data,y=getDataPoints(g,c,p,r,s,t,i,o);d.push(y);var f=splitPoints(y);if("dash"==e.lineType){let i=e.dashLength?e.dashLength:8;i*=t.pixelRatio,a.setLineDash([i,i])}a.beginPath(),a.setStrokeStyle(e.color),a.setLineWidth(n.width),f.forEach(function(e){if(1===e.length)a.moveTo(e[0].x,e[0].y),a.arc(e[0].x,e[0].y,1,0,2*Math.PI);else{a.moveTo(e[0].x,e[0].y);let i=0;if("curve"===n.type){for(let o,n=0;n<e.length;n++)if(o=e[n],0==i&&o.x>h&&(a.moveTo(o.x,o.y),i=1),0<n&&o.x>h&&o.x<x){var t=createCurveControlPoints(e,n-1);a.bezierCurveTo(t.ctrA.x,t.ctrA.y,t.ctrB.x,t.ctrB.y,o.x,o.y)}}else for(let t,o=0;o<e.length;o++)t=e[o],0==i&&t.x>h&&(a.moveTo(t.x,t.y),i=1),0<o&&t.x>h&&t.x<x&&a.lineTo(t.x,t.y);a.moveTo(e[0].x,e[0].y)}}),a.stroke(),a.setLineDash([]),!1!==t.dataPointShape&&drawPointShape(y,e.color,e.pointShape,a,t)}),!1!==t.dataLabel&&1===o&&e.forEach(function(e){let n,l,d;n=[].concat(t.chartData.yAxisData.ranges[e.index]),l=n.pop(),d=n.shift();var h=e.data,x=getDataPoints(h,l,d,r,s,t,i,o);drawPointText(x,e,i,a)}),a.restore(),{xAxisPoints:r,calPoints:d,eachSpacing:s}}function drawMixDataPoints(e,t,i,a){let o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,n=t.chartData.xAxisData,l=n.xAxisPoints,r=n.eachSpacing,s=t.height-t.area[2],d=[];var h=0,x=0;e.forEach(function(e){"column"==e.type&&(x+=1)}),a.save();let c=-2,p=l.length+2,g=0,y=t.width+r;if(t._scrollDistance_&&0!==t._scrollDistance_&&!0===t.enableScroll&&(a.translate(t._scrollDistance_,0),c=Math.floor(-t._scrollDistance_/r)-2,p=c+t.xAxis.itemCount+4,g=-t._scrollDistance_-r+t.area[3],y=g+(t.xAxis.itemCount+4)*r),e.forEach(function(e){let n,f,u;n=[].concat(t.chartData.yAxisData.ranges[e.index]),f=n.pop(),u=n.shift();var m=e.data,S=getDataPoints(m,f,u,l,r,t,i,o);if(d.push(S),"column"==e.type){S=fixColumeData(S,r,x,h,i,t);for(let o,n=0;n<S.length;n++)if(o=S[n],null!==o&&n>c&&n<p){a.beginPath(),a.setStrokeStyle(o.color||e.color),a.setLineWidth(1),a.setFillStyle(o.color||e.color);var T=o.x-o.width/2,A=t.height-o.y-t.area[2];a.moveTo(T,o.y),a.moveTo(T-1,o.y),a.lineTo(T+o.width-2,o.y),a.lineTo(T+o.width-2,t.height-t.area[2]),a.lineTo(T,t.height-t.area[2]),a.lineTo(T,o.y),a.closePath(),a.stroke(),a.fill(),a.closePath(),a.fill()}h+=1}if("area"==e.type){let o=splitPoints(S);for(let n,l=0;l<o.length;l++){if(n=o[l],a.beginPath(),a.setStrokeStyle(e.color),a.setFillStyle(hexToRgb(e.color,.2)),a.setLineWidth(2*t.pixelRatio),1<n.length){var b=n[0];let t=n[n.length-1];a.moveTo(b.x,b.y);let i=0;if("curve"===e.style){for(let e,t=0;t<n.length;t++)if(e=n[t],0==i&&e.x>g&&(a.moveTo(e.x,e.y),i=1),0<t&&e.x>g&&e.x<y){var P=createCurveControlPoints(n,t-1);a.bezierCurveTo(P.ctrA.x,P.ctrA.y,P.ctrB.x,P.ctrB.y,e.x,e.y)}}else for(let e,t=0;t<n.length;t++)e=n[t],0==i&&e.x>g&&(a.moveTo(e.x,e.y),i=1),0<t&&e.x>g&&e.x<y&&a.lineTo(e.x,e.y);a.lineTo(t.x,s),a.lineTo(b.x,s),a.lineTo(b.x,b.y)}else{let e=n[0];a.moveTo(e.x-r/2,e.y),a.lineTo(e.x+r/2,e.y),a.lineTo(e.x+r/2,s),a.lineTo(e.x-r/2,s),a.moveTo(e.x-r/2,e.y)}a.closePath(),a.fill()}}if("line"==e.type){var _=splitPoints(S);_.forEach(function(i){if("dash"==e.lineType){let i=e.dashLength?e.dashLength:8;i*=t.pixelRatio,a.setLineDash([i,i])}if(a.beginPath(),a.setStrokeStyle(e.color),a.setLineWidth(2*t.pixelRatio),1===i.length)a.moveTo(i[0].x,i[0].y),a.arc(i[0].x,i[0].y,1,0,2*Math.PI);else{a.moveTo(i[0].x,i[0].y);let t=0;if("curve"==e.style){for(let e,n=0;n<i.length;n++)if(e=i[n],0==t&&e.x>g&&(a.moveTo(e.x,e.y),t=1),0<n&&e.x>g&&e.x<y){var o=createCurveControlPoints(i,n-1);a.bezierCurveTo(o.ctrA.x,o.ctrA.y,o.ctrB.x,o.ctrB.y,e.x,e.y)}}else for(let e,o=0;o<i.length;o++)e=i[o],0==t&&e.x>g&&(a.moveTo(e.x,e.y),t=1),0<o&&e.x>g&&e.x<y&&a.lineTo(e.x,e.y);a.moveTo(i[0].x,i[0].y)}a.stroke(),a.setLineDash([])})}"point"==e.type&&(e.addPoint=!0),!0==e.addPoint&&"column"!==e.type&&drawPointShape(S,e.color,e.pointShape,a,t)}),!1!==t.dataLabel&&1===o){var h=0;e.forEach(function(e){let n,s,d;n=[].concat(t.chartData.yAxisData.ranges[e.index]),s=n.pop(),d=n.shift();var c=e.data,p=getDataPoints(c,s,d,l,r,t,i,o);"column"===e.type?(p=fixColumeData(p,r,x,h,i,t),drawPointText(p,e,i,a),h+=1):drawPointText(p,e,i,a)})}return a.restore(),{xAxisPoints:l,calPoints:d,eachSpacing:r}}function drawToolTipBridge(e,t,i,a,o,n){var l=e.extra.tooltip||{};l.horizentalLine&&e.tooltip&&1===a&&("line"==e.type||"area"==e.type||"column"==e.type||"candle"==e.type||"mix"==e.type)&&drawToolTipHorizentalLine(e,t,i,o,n),i.save(),e._scrollDistance_&&0!==e._scrollDistance_&&!0===e.enableScroll&&i.translate(e._scrollDistance_,0),e.tooltip&&e.tooltip.textList&&e.tooltip.textList.length&&1===a&&drawToolTip(e.tooltip.textList,e.tooltip.offset,e,t,i,o,n),i.restore()}function drawXAxis(e,t,i,a){var o=Math.ceil;let n=t.chartData.xAxisData,l=n.xAxisPoints,r=n.startX,s=n.endX,d=n.eachSpacing;var h="center";("line"==t.type||"area"==t.type)&&(h=t.xAxis.boundaryGap);var x=t.height-t.area[2],c=t.area[0];if(t.enableScroll&&t.xAxis.scrollShow){var p=t.height-t.area[2]+i.xAxisHeight,g=s-r,y=d*(l.length-1),f=0;t._scrollDistance_&&(f=-t._scrollDistance_*g/y),a.beginPath(),a.setLineCap("round"),a.setLineWidth(6*t.pixelRatio),a.setStrokeStyle(t.xAxis.scrollBackgroundColor||"#EFEBEF"),a.moveTo(r,p),a.lineTo(s,p),a.stroke(),a.closePath(),a.beginPath(),a.setLineCap("round"),a.setLineWidth(6*t.pixelRatio),a.setStrokeStyle(t.xAxis.scrollColor||"#A6A6A6"),a.moveTo(r+f,p),a.lineTo(r+f+g*g/y,p),a.stroke(),a.closePath(),a.setLineCap("butt")}if(a.save(),t._scrollDistance_&&0!==t._scrollDistance_&&a.translate(t._scrollDistance_,0),!0===t.xAxis.calibration&&(a.setStrokeStyle(t.xAxis.gridColor||"#cccccc"),a.setLineCap("butt"),a.setLineWidth(1*t.pixelRatio),l.forEach(function(e,i){0<i&&(a.beginPath(),a.moveTo(e-d/2,x),a.lineTo(e-d/2,x+3*t.pixelRatio),a.closePath(),a.stroke())})),!0!==t.xAxis.disableGrid&&(a.setStrokeStyle(t.xAxis.gridColor||"#cccccc"),a.setLineCap("butt"),a.setLineWidth(1*t.pixelRatio),"dash"==t.xAxis.gridType&&a.setLineDash([t.xAxis.dashLength,t.xAxis.dashLength]),t.xAxis.gridEval=t.xAxis.gridEval||1,l.forEach(function(e,i){0==i%t.xAxis.gridEval&&(a.beginPath(),a.moveTo(e,x),a.lineTo(e,c),a.stroke())}),a.setLineDash([])),!0!==t.xAxis.disabled){let n=e.length;t.xAxis.labelCount&&(n=t.xAxis.itemCount?o(e.length/t.xAxis.itemCount*t.xAxis.labelCount):t.xAxis.labelCount,n-=1);let r=o(e.length/n),s=[],c=e.length;for(let t=0;t<c;t++)0==t%r?s.push(e[t]):s.push("");s[c-1]=e[c-1];var u=t.xAxis.fontSize||i.fontSize;0===i._xAxisTextAngle_?s.forEach(function(e,o){var n=-measureText(e+"",u)/2;"center"==h&&(n+=d/2);var r=0;t.xAxis.scrollShow&&(r=6*t.pixelRatio),a.beginPath(),a.setFontSize(u),a.setFillStyle(t.xAxis.fontColor||"#666666"),a.fillText(e+"",l[o]+n,x+u+(i.xAxisHeight-r-u)/2),a.closePath(),a.stroke()}):s.forEach(function(e,o){a.save(),a.beginPath(),a.setFontSize(u),a.setFillStyle(t.xAxis.fontColor||"#666666");var n=measureText(e+"",u),r=-n;"center"==h&&(r+=d/2);var s=calRotateTranslate(l[o]+d/2,x+u/2+5,t.height),c=s.transX,p=s.transY;a.rotate(-1*i._xAxisTextAngle_),a.translate(c,p),a.fillText(e+"",l[o]+r,x+u+5),a.closePath(),a.stroke(),a.restore()})}a.restore(),t.xAxis.axisLine&&(a.beginPath(),a.setStrokeStyle(t.xAxis.axisLineColor),a.setLineWidth(1*t.pixelRatio),a.moveTo(r,t.height-t.area[2]),a.lineTo(s,t.height-t.area[2]),a.stroke())}function drawYAxisGrid(e,t,i,a){if(!0===t.yAxis.disableGrid)return;let o=t.height-t.area[0]-t.area[2],n=o/t.yAxis.splitNumber,l=t.area[3],r=t.chartData.xAxisData.xAxisPoints,s=t.chartData.xAxisData.eachSpacing,d=s*(r.length-1),h=[];for(let o=0;o<t.yAxis.splitNumber+1;o++)h.push(t.height-t.area[2]-n*o);a.save(),t._scrollDistance_&&0!==t._scrollDistance_&&a.translate(t._scrollDistance_,0),"dash"==t.yAxis.gridType&&a.setLineDash([t.yAxis.dashLength,t.yAxis.dashLength]),a.setStrokeStyle(t.yAxis.gridColor),a.setLineWidth(1*t.pixelRatio),h.forEach(function(e){a.beginPath(),a.moveTo(l,e),a.lineTo(l+d,e),a.stroke()}),a.setLineDash([]),a.restore()}function drawYAxis(e,t,a,o){if(!0===t.yAxis.disabled)return;var i=t.height-t.area[0]-t.area[2],n=i/t.yAxis.splitNumber,l=t.area[3],r=t.width-t.area[1],s=t.height-t.area[2],d=s+a.xAxisHeight;t.xAxis.scrollShow&&(d-=3*t.pixelRatio),t.xAxis.rotateLabel&&(d=t.height-t.area[2]+3),o.beginPath(),o.setFillStyle(t.background||"#ffffff"),0>t._scrollDistance_&&o.fillRect(0,0,l,d),!0==t.enableScroll&&o.fillRect(r,0,t.width,d),o.closePath(),o.stroke();var h=[];for(let l=0;l<=t.yAxis.splitNumber;l++)h.push(t.area[0]+n*l);let x=t.area[3],c=t.width-t.area[1];for(let n,l=0;l<t.yAxis.data.length;l++)if(n=t.yAxis.data[l],!0!==n.disabled){let e=t.chartData.yAxisData.rangesFormat[l],i=n.fontSize||a.fontSize,r=t.chartData.yAxisData.yAxisWidth[l];if(e.forEach(function(e,a){var l=h[a]?h[a]:s;o.beginPath(),o.setFontSize(i),o.setLineWidth(1*t.pixelRatio),o.setStrokeStyle(n.axisLineColor||"#cccccc"),o.setFillStyle(n.fontColor||"#666666"),"left"==r.position?(o.fillText(e+"",x-r.width,l+i/2),!0==n.calibration&&(o.moveTo(x,l),o.lineTo(x-3*t.pixelRatio,l))):(o.fillText(e+"",c+4*t.pixelRatio,l+i/2),!0==n.calibration&&(o.moveTo(c,l),o.lineTo(c+3*t.pixelRatio,l))),o.closePath(),o.stroke()}),!1!==n.axisLine&&(o.beginPath(),o.setStrokeStyle(n.axisLineColor||"#cccccc"),o.setLineWidth(1*t.pixelRatio),"left"==r.position?(o.moveTo(x,t.height-t.area[2]),o.lineTo(x,t.area[0])):(o.moveTo(c,t.height-t.area[2]),o.lineTo(c,t.area[0])),o.stroke()),t.yAxis.showTitle){let e=n.titleFontSize||a.fontSize,i=n.title;o.beginPath(),o.setFontSize(e),o.setFillStyle(n.titleFontColor||"#666666"),"left"==r.position?o.fillText(i,x-measureText(i,e)/2,t.area[0]-10*t.pixelRatio):o.fillText(i,c-measureText(i,e)/2,t.area[0]-10*t.pixelRatio),o.closePath(),o.stroke()}"left"==r.position?x-=r.width+t.yAxis.padding:c+=r.width+t.yAxis.padding}}function drawLegend(e,t,i,a,o){if(!1===t.legend.show)return;let n=o.legendData,l=n.points,r=n.area,s=t.legend.padding,d=t.legend.fontSize,h=15*t.pixelRatio,x=5*t.pixelRatio,c=t.legend.itemGap,p=Math.max(t.legend.lineHeight*t.pixelRatio,d);a.beginPath(),a.setLineWidth(t.legend.borderWidth),a.setStrokeStyle(t.legend.borderColor),a.setFillStyle(t.legend.backgroundColor),a.moveTo(r.start.x,r.start.y),a.rect(r.start.x,r.start.y,r.width,r.height),a.closePath(),a.fill(),a.stroke(),l.forEach(function(e,o){let l=0,g=0;l=n.widthArr[o],g=n.heightArr[o];let y=0,f=0;"top"==t.legend.position||"bottom"==t.legend.position?(y=r.start.x+(r.width-l)/2,f=r.start.y+s+o*p):(l=0==o?0:n.widthArr[o-1],y=r.start.x+s+l,f=r.start.y+s+(r.height-g)/2),a.setFontSize(i.fontSize);for(let n,l=0;l<e.length;l++){switch(n=e[l],n.area=[0,0,0,0],n.area[0]=y,n.area[1]=f,n.area[3]=f+p,a.beginPath(),a.setLineWidth(1*t.pixelRatio),a.setStrokeStyle(n.show?n.color:t.legend.hiddenColor),a.setFillStyle(n.show?n.color:t.legend.hiddenColor),n.legendShape){case"line":a.moveTo(y,f+.5*p-2*t.pixelRatio),a.fillRect(y,f+.5*p-2*t.pixelRatio,15*t.pixelRatio,4*t.pixelRatio);break;case"triangle":a.moveTo(y+7.5*t.pixelRatio,f+.5*p-5*t.pixelRatio),a.lineTo(y+2.5*t.pixelRatio,f+.5*p+5*t.pixelRatio),a.lineTo(y+12.5*t.pixelRatio,f+.5*p+5*t.pixelRatio),a.lineTo(y+7.5*t.pixelRatio,f+.5*p-5*t.pixelRatio);break;case"diamond":a.moveTo(y+7.5*t.pixelRatio,f+.5*p-5*t.pixelRatio),a.lineTo(y+2.5*t.pixelRatio,f+.5*p),a.lineTo(y+7.5*t.pixelRatio,f+.5*p+5*t.pixelRatio),a.lineTo(y+12.5*t.pixelRatio,f+.5*p),a.lineTo(y+7.5*t.pixelRatio,f+.5*p-5*t.pixelRatio);break;case"circle":a.moveTo(y+7.5*t.pixelRatio,f+.5*p),a.arc(y+7.5*t.pixelRatio,f+.5*p,5*t.pixelRatio,0,2*Math.PI);break;case"rect":a.moveTo(y,f+.5*p-5*t.pixelRatio),a.fillRect(y,f+.5*p-5*t.pixelRatio,15*t.pixelRatio,10*t.pixelRatio);break;default:a.moveTo(y,f+.5*p-5*t.pixelRatio),a.fillRect(y,f+.5*p-5*t.pixelRatio,15*t.pixelRatio,10*t.pixelRatio);}a.closePath(),a.fill(),a.stroke(),y+=h+x;a.beginPath(),a.setFontSize(d),a.setFillStyle(n.show?t.legend.fontColor:t.legend.hiddenColor),a.fillText(n.name,y,f+(.5*p+.5*d-2)),a.closePath(),a.stroke(),"top"==t.legend.position||"bottom"==t.legend.position?(y+=measureText(n.name,d)+c,n.area[2]=y):(n.area[2]=y+measureText(n.name,d)+c,y-=h+x,f+=p)}})}function drawPieDataPoints(e,t,a,o){var n=Math.PI,l=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,r=assign({},{activeOpacity:.5,activeRadius:10*t.pixelRatio,offsetAngle:0,labelWidth:15*t.pixelRatio,ringWidth:0,border:!1,borderWidth:2,borderColor:"#FFFFFF"},t.extra.pie),s={x:t.area[3]+(t.width-t.area[1]-t.area[3])/2,y:t.area[0]+(t.height-t.area[0]-t.area[2])/2};0==a.pieChartLinePadding&&(a.pieChartLinePadding=r.activeRadius);var d=Math.min((t.width-t.area[1]-t.area[3])/2-a.pieChartLinePadding-a.pieChartTextPadding-a._pieTextMaxLength_,(t.height-t.area[0]-t.area[2])/2-a.pieChartLinePadding-a.pieChartTextPadding);e=getPieDataPoints(e,d,l);var h=r.activeRadius;if(e=e.map(function(e){return e._start_+=r.offsetAngle*n/180,e}),e.forEach(function(e,i){t.tooltip&&t.tooltip.index==i&&(o.beginPath(),o.setFillStyle(hexToRgb(e.color,t.extra.pie.activeOpacity||.5)),o.moveTo(s.x,s.y),o.arc(s.x,s.y,e._radius_+h,e._start_,e._start_+2*e._proportion_*n),o.closePath(),o.fill()),o.beginPath(),o.setLineWidth(r.borderWidth*t.pixelRatio),o.lineJoin="round",o.setStrokeStyle(r.borderColor),o.setFillStyle(e.color),o.moveTo(s.x,s.y),o.arc(s.x,s.y,e._radius_,e._start_,e._start_+2*e._proportion_*n),o.closePath(),o.fill(),!0==r.border&&o.stroke()}),"ring"===t.type){var x=.6*d;"number"==typeof t.extra.pie.ringWidth&&0<t.extra.pie.ringWidth&&(x=Math.max(0,d-t.extra.pie.ringWidth)),o.beginPath(),o.setFillStyle(t.background||"#ffffff"),o.moveTo(s.x,s.y),o.arc(s.x,s.y,x,0,2*n),o.closePath(),o.fill()}if(!1!==t.dataLabel&&1===l){for(var c=!1,p=0,g=e.length;p<g;p++)if(0<e[p].data){c=!0;break}c&&drawPieText(e,t,a,o,d,s)}return 1===l&&"ring"===t.type&&drawRingTitle(t,a,o,s),{center:s,radius:d,series:e}}function drawRoseDataPoints(e,t,a,o){var n=Math.PI,l=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,r=assign({},{type:"area",activeOpacity:.5,activeRadius:10*t.pixelRatio,offsetAngle:0,labelWidth:15*t.pixelRatio,border:!1,borderWidth:2,borderColor:"#FFFFFF"},t.extra.rose);0==a.pieChartLinePadding&&(a.pieChartLinePadding=r.activeRadius);var s={x:t.area[3]+(t.width-t.area[1]-t.area[3])/2,y:t.area[0]+(t.height-t.area[0]-t.area[2])/2},d=Math.min((t.width-t.area[1]-t.area[3])/2-a.pieChartLinePadding-a.pieChartTextPadding-a._pieTextMaxLength_,(t.height-t.area[0]-t.area[2])/2-a.pieChartLinePadding-a.pieChartTextPadding),h=r.minRadius||.5*d;e=getRoseDataPoints(e,r.type,h,d,l);var x=r.activeRadius;if(e=e.map(function(e){return e._start_+=(r.offsetAngle||0)*n/180,e}),e.forEach(function(e,i){t.tooltip&&t.tooltip.index==i&&(o.beginPath(),o.setFillStyle(hexToRgb(e.color,r.activeOpacity||.5)),o.moveTo(s.x,s.y),o.arc(s.x,s.y,x+e._radius_,e._start_,e._start_+2*e._rose_proportion_*n),o.closePath(),o.fill()),o.beginPath(),o.setLineWidth(r.borderWidth*t.pixelRatio),o.lineJoin="round",o.setStrokeStyle(r.borderColor),o.setFillStyle(e.color),o.moveTo(s.x,s.y),o.arc(s.x,s.y,e._radius_,e._start_,e._start_+2*e._rose_proportion_*n),o.closePath(),o.fill(),!0==r.border&&o.stroke()}),!1!==t.dataLabel&&1===l){for(var c=!1,p=0,g=e.length;p<g;p++)if(0<e[p].data){c=!0;break}c&&drawPieText(e,t,a,o,d,s)}return{center:s,radius:d,series:e}}function drawArcbarDataPoints(e,t,i,a){var o=Math.PI,n=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,l=assign({},{startAngle:.75,endAngle:.25,type:"default",width:12*t.pixelRatio,gap:2*t.pixelRatio},t.extra.arcbar);e=getArcbarDataPoints(e,l,n);var r=l.center?l.center:{x:t.width/2,y:t.height/2};var s;l.radius?s=l.radius:(s=Math.min(r.x,r.y),s-=5*t.pixelRatio,s-=l.width/2);for(let n,d=0;d<e.length;d++)n=e[d],a.setLineWidth(l.width),a.setStrokeStyle(l.backgroundColor||"#E9E9E9"),a.setLineCap("round"),a.beginPath(),"default"==l.type?a.arc(r.x,r.y,s-(l.width+l.gap)*d,l.startAngle*o,l.endAngle*o,!1):a.arc(r.x,r.y,s-(l.width+l.gap)*d,0,2*o,!1),a.stroke(),a.setLineWidth(l.width),a.setStrokeStyle(n.color),a.setLineCap("round"),a.beginPath(),a.arc(r.x,r.y,s-(l.width+l.gap)*d,l.startAngle*o,n._proportion_*o,!1),a.stroke();return drawRingTitle(t,i,a,r),{center:r,radius:s,series:e}}function drawGaugeDataPoints(e,t,a,i,o){var n=Math.PI,l=5<arguments.length&&void 0!==arguments[5]?arguments[5]:1,r=assign({},{type:"default",startAngle:.75,endAngle:.25,width:15,splitLine:{fixRadius:0,splitNumber:10,width:15,color:"#FFFFFF",childNumber:5,childWidth:5},pointer:{width:15,color:"auto"}},a.extra.gauge);null==r.oldAngle&&(r.oldAngle=r.startAngle),null==r.oldData&&(r.oldData=0),e=getGaugeAxisPoints(e,r.startAngle,r.endAngle);var s={x:a.width/2,y:a.height/2},d=Math.min(s.x,s.y);d-=5*a.pixelRatio,d-=r.width/2;var h=d-r.width,x=0;if("progress"==r.type){var c=d-3*r.width;o.beginPath();let e=o.createLinearGradient(s.x,s.y-c,s.x,s.y+c);e.addColorStop("0",hexToRgb(t[0].color,.3)),e.addColorStop("1.0",hexToRgb("#FFFFFF",.1)),o.setFillStyle(e),o.arc(s.x,s.y,c,0,2*n,!1),o.fill(),o.setLineWidth(r.width),o.setStrokeStyle(hexToRgb(t[0].color,.3)),o.setLineCap("round"),o.beginPath(),o.arc(s.x,s.y,h,r.startAngle*n,r.endAngle*n,!1),o.stroke(),x=r.startAngle-r.endAngle+1;let i=x/r.splitLine.splitNumber,p=x/r.splitLine.splitNumber/r.splitLine.childNumber,g=-d-.5*r.width-r.splitLine.fixRadius,y=-d-r.width-r.splitLine.fixRadius+r.splitLine.width;o.save(),o.translate(s.x,s.y),o.rotate((r.startAngle-1)*n);let f=r.splitLine.splitNumber*r.splitLine.childNumber+1,u=t[0].data*l;for(let e=0;e<f;e++)o.beginPath(),u>e/f?o.setStrokeStyle(hexToRgb(t[0].color,1)):o.setStrokeStyle(hexToRgb(t[0].color,.3)),o.setLineWidth(3*a.pixelRatio),o.moveTo(g,0),o.lineTo(y,0),o.stroke(),o.rotate(p*n);o.restore(),t=getArcbarDataPoints(t,r,l),o.setLineWidth(r.width),o.setStrokeStyle(t[0].color),o.setLineCap("round"),o.beginPath(),o.arc(s.x,s.y,h,r.startAngle*n,t[0]._proportion_*n,!1),o.stroke();let m=d-2.5*r.width;o.save(),o.translate(s.x,s.y),o.rotate((t[0]._proportion_-1)*n),o.beginPath(),o.setLineWidth(r.width/3);let S=o.createLinearGradient(0,.6*-m,0,.6*m);S.addColorStop("0",hexToRgb("#FFFFFF",0)),S.addColorStop("0.5",hexToRgb(t[0].color,1)),S.addColorStop("1.0",hexToRgb("#FFFFFF",0)),o.setStrokeStyle(S),o.arc(0,0,m,.85*n,1.15*n,!1),o.stroke(),o.beginPath(),o.setLineWidth(1),o.setStrokeStyle(t[0].color),o.setFillStyle(t[0].color),o.moveTo(-m-r.width/3/2,-4),o.lineTo(-m-r.width/3/2-4,0),o.lineTo(-m-r.width/3/2,4),o.lineTo(-m-r.width/3/2,-4),o.stroke(),o.fill(),o.restore()}else{o.setLineWidth(r.width),o.setLineCap("butt");for(let t,a=0;a<e.length;a++)t=e[a],o.beginPath(),o.setStrokeStyle(t.color),o.arc(s.x,s.y,d,t._startAngle_*n,t._endAngle_*n,!1),o.stroke();o.save(),x=r.startAngle-r.endAngle+1;let c=x/r.splitLine.splitNumber,p=x/r.splitLine.splitNumber/r.splitLine.childNumber,g=-d-.5*r.width-r.splitLine.fixRadius,y=-d-.5*r.width-r.splitLine.fixRadius+r.splitLine.width,f=-d-.5*r.width-r.splitLine.fixRadius+r.splitLine.childWidth;o.translate(s.x,s.y),o.rotate((r.startAngle-1)*n);for(let e=0;e<r.splitLine.splitNumber+1;e++)o.beginPath(),o.setStrokeStyle(r.splitLine.color),o.setLineWidth(2*a.pixelRatio),o.moveTo(g,0),o.lineTo(y,0),o.stroke(),o.rotate(c*n);o.restore(),o.save(),o.translate(s.x,s.y),o.rotate((r.startAngle-1)*n);for(let e=0;e<r.splitLine.splitNumber*r.splitLine.childNumber+1;e++)o.beginPath(),o.setStrokeStyle(r.splitLine.color),o.setLineWidth(1*a.pixelRatio),o.moveTo(g,0),o.lineTo(f,0),o.stroke(),o.rotate(p*n);o.restore(),t=getGaugeDataPoints(t,e,r,l);for(let e,a=0;a<t.length;a++)e=t[a],o.save(),o.translate(s.x,s.y),o.rotate((e._proportion_-1)*n),o.beginPath(),o.setFillStyle(e.color),o.moveTo(r.pointer.width,0),o.lineTo(0,-r.pointer.width/2),o.lineTo(-h,0),o.lineTo(0,r.pointer.width/2),o.lineTo(r.pointer.width,0),o.closePath(),o.fill(),o.beginPath(),o.setFillStyle("#FFFFFF"),o.arc(0,0,r.pointer.width/6,0,2*n,!1),o.fill(),o.restore();!1!==a.dataLabel&&drawGaugeLabel(r,d,s,a,i,o)}return drawRingTitle(a,i,o,s),1===l&&"gauge"===a.type&&(a.extra.gauge.oldAngle=t[0]._proportion_,a.extra.gauge.oldData=t[0].data),{center:s,radius:d,innerRadius:h,categories:e,totalAngle:x}}function drawRadarDataPoints(e,t,a,o){var n=Math.cos,l=Math.sin,r=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,s=assign({},{gridColor:"#cccccc",labelColor:"#666666",opacity:.2,gridCount:3},t.extra.radar),d=getRadarCoordinateSeries(t.categories.length),h={x:t.area[3]+(t.width-t.area[1]-t.area[3])/2,y:t.area[0]+(t.height-t.area[0]-t.area[2])/2},x=Math.min(h.x-(getMaxTextListLength(t.categories)+a.radarLabelTextMargin),h.y-a.radarLabelTextMargin);x-=t.padding[1],o.beginPath(),o.setLineWidth(1*t.pixelRatio),o.setStrokeStyle(s.gridColor),d.forEach(function(e){var t=convertCoordinateOrigin(x*n(e),x*l(e),h);o.moveTo(h.x,h.y),o.lineTo(t.x,t.y)}),o.stroke(),o.closePath();for(var c=function(e){var i={};o.beginPath(),o.setLineWidth(1*t.pixelRatio),o.setStrokeStyle(s.gridColor),d.forEach(function(t,a){var r=convertCoordinateOrigin(x/s.gridCount*e*n(t),x/s.gridCount*e*l(t),h);0===a?(i=r,o.moveTo(r.x,r.y)):o.lineTo(r.x,r.y)}),o.lineTo(i.x,i.y),o.stroke(),o.closePath()},p=1;p<=s.gridCount;p++)c(p);var g=getRadarDataPoints(d,h,x,e,t,r);return g.forEach(function(e){if(o.beginPath(),o.setFillStyle(hexToRgb(e.color,s.opacity)),e.data.forEach(function(e,t){0===t?o.moveTo(e.position.x,e.position.y):o.lineTo(e.position.x,e.position.y)}),o.closePath(),o.fill(),!1!==t.dataPointShape){var i=e.data.map(function(e){return e.position});drawPointShape(i,e.color,e.pointShape,o,t)}}),drawRadarLabel(d,x,h,t,a,o),{center:h,radius:x,angleList:d}}function normalInt(e,t,a){a=0==a?1:a;for(var o=[],n=0;n<a;n++)o[n]=Math.random();return Math.floor(o.reduce(function(e,t){return e+t})/a*(t-e))+e}function collisionNew(e,t,a,o){var n=!1;for(let l=0;l<t.length;l++)if(t[l].area)if(!(e[3]<t[l].area[1]||e[0]>t[l].area[2]||e[1]>t[l].area[3]||e[2]<t[l].area[0])){n=!0;break}else if(0>e[0]||0>e[1]||e[2]>a||e[3]>o){n=!0;break}else n=!1;return n}function getBoundingBox(e){var t,a={};a.xMin=180,a.xMax=0,a.yMin=90,a.yMax=0;for(var o,n=0;n<e.length;n++){o=e[n].geometry.coordinates;for(var l=0;l<o.length;l++){t=o[l],1==t.length&&(t=t[0]);for(var r=0;r<t.length;r++){var s=t[r][0],d=t[r][1],h={x:s,y:d};a.xMin=a.xMin<h.x?a.xMin:h.x,a.xMax=a.xMax>h.x?a.xMax:h.x,a.yMin=a.yMin<h.y?a.yMin:h.y,a.yMax=a.yMax>h.y?a.yMax:h.y}}}return a}function coordinateToPoint(e,t,i,a,o,n){return{x:(t-i.xMin)*a+o,y:(i.yMax-e)*a+n}}function pointToCoordinate(e,t,i,a,o,n){return{x:(t-o)/a+i.xMin,y:i.yMax-(e-n)/a}}function isRayIntersectsSegment(e,t,i){if(t[1]==i[1])return!1;if(t[1]>e[1]&&i[1]>e[1])return!1;if(t[1]<e[1]&&i[1]<e[1])return!1;if(t[1]==e[1]&&i[1]>e[1])return!1;if(i[1]==e[1]&&t[1]>e[1])return!1;if(t[0]<e[0]&&i[1]<e[1])return!1;let a=i[0]-(i[0]-t[0])*(i[1]-e[1])/(i[1]-t[1]);return!(a<e[0])}function isPoiWithinPoly(e,t){let i=0;for(let a,o=0;o<t.length;o++){a=t[o][0],1==t.length&&(a=t[o][0]);for(let t=0;t<a.length-1;t++){let o=a[t],n=a[t+1];isRayIntersectsSegment(e,o,n)&&(i+=1)}}return!(1!=i%2)}function drawMapDataPoints(e,t,a,o){var n,l,r=Math.abs,s=assign({},{border:!0,borderWidth:1,borderColor:"#666666",fillOpacity:.6,activeBorderColor:"#f04864",activeFillColor:"#facc14",activeFillOpacity:1},t.extra.map),d=e,h=getBoundingBox(d),x=t.width/r(h.xMax-h.xMin),c=t.height/r(h.yMax-h.yMin),p=x<c?x:c,g=t.width/2-r(h.xMax-h.xMin)/2*p,y=t.height/2-r(h.yMax-h.yMin)/2*p;o.beginPath(),o.clearRect(0,0,t.width,t.height),o.setFillStyle(t.background||"#FFFFFF"),o.rect(0,0,t.width,t.height),o.fill();for(var f=0;f<d.length;f++){o.beginPath(),o.setLineWidth(s.borderWidth*t.pixelRatio),o.setStrokeStyle(s.borderColor),o.setFillStyle(hexToRgb(e[f].color,s.fillOpacity)),t.tooltip&&t.tooltip.index==f&&(o.setStrokeStyle(s.activeBorderColor),o.setFillStyle(hexToRgb(s.activeFillColor,s.activeFillOpacity)));for(var u=d[f].geometry.coordinates,m=0;m<u.length;m++){n=u[m],1==n.length&&(n=n[0]);for(var S=0;S<n.length;S++)l=coordinateToPoint(n[S][1],n[S][0],h,p,g,y),0==S?(o.beginPath(),o.moveTo(l.x,l.y)):o.lineTo(l.x,l.y);o.fill(),!0==s.border&&o.stroke()}if(!0==t.dataLabel){var T=d[f].properties.centroid;if(T){l=coordinateToPoint(T[1],T[0],h,p,g,y);let e=d[f].textSize||a.fontSize,t=d[f].properties.name;o.beginPath(),o.setFontSize(e),o.setFillStyle(d[f].textColor||"#666666"),o.fillText(t,l.x-measureText(t,e)/2,l.y+e/2),o.closePath(),o.stroke()}}}t.chartData.mapData={bounds:h,scale:p,xoffset:g,yoffset:y},drawToolTipBridge(t,a,o,1),o.draw()}function getWordCloudPoint(e,t){let a=e.series.sort(function(e,t){return parseInt(t.textSize)-parseInt(e.textSize)});switch(t){case"normal":for(let t=0;t<a.length;t++){let i,o,n,l=a[t].name,r=a[t].textSize,s=measureText(l,r),d=0;for(;;){d++,i=normalInt(-e.width/2,e.width/2,5)-s/2,o=normalInt(-e.height/2,e.height/2,5)+r/2,n=[i-5+e.width/2,o-5-r+e.height/2,i+s+5+e.width/2,o+5+e.height/2];let t=collisionNew(n,a,e.width,e.height);if(!t)break;if(1e3==d){n=[-100,-100,-100,-100];break}}a[t].area=n}break;case"vertical":function o(){return!!(.7<Math.random())};for(let t=0;t<a.length;t++){let i,n,l,r,s=a[t].name,d=a[t].textSize,h=measureText(s,d),x=o(),c=0;for(;;){c++;let t;if(x?(i=normalInt(-e.width/2,e.width/2,5)-h/2,n=normalInt(-e.height/2,e.height/2,5)+d/2,l=[n-5-h+e.width/2,-i-5+e.height/2,n+5+e.width/2,-i+d+5+e.height/2],r=[e.width-(e.width/2-e.height/2)-(-i+d+5+e.height/2)-5,e.height/2-e.width/2+(n-5-h+e.width/2)-5,e.width-(e.width/2-e.height/2)-(-i+d+5+e.height/2)+d,e.height/2-e.width/2+(n-5-h+e.width/2)+h+5],t=collisionNew(r,a,e.height,e.width)):(i=normalInt(-e.width/2,e.width/2,5)-h/2,n=normalInt(-e.height/2,e.height/2,5)+d/2,l=[i-5+e.width/2,n-5-d+e.height/2,i+h+5+e.width/2,n+5+e.height/2],t=collisionNew(l,a,e.width,e.height)),!t)break;if(1e3==c){l=[-1e3,-1e3,-1e3,-1e3];break}}x?(a[t].area=r,a[t].areav=l):a[t].area=l,a[t].rotate=x};}return a}function drawWordCloudDataPoints(e,t,i,a){let o=4<arguments.length&&arguments[4]!==void 0?arguments[4]:1,n=assign({},{type:"normal",autoColors:!0},t.extra.word);a.beginPath(),a.setFillStyle(t.background||"#FFFFFF"),a.rect(0,0,t.width,t.height),a.fill(),a.save();let l=t.chartData.wordCloudData;a.translate(t.width/2,t.height/2);for(let n=0;n<l.length;n++){a.save(),l[n].rotate&&a.rotate(90*Math.PI/180);let e=l[n].name,i=l[n].textSize,r=measureText(e,i);a.beginPath(),a.setStrokeStyle(l[n].color),a.setFillStyle(l[n].color),a.setFontSize(i),l[n].rotate?0<l[n].areav[0]&&(t.tooltip?t.tooltip.index==n?a.strokeText(e,(l[n].areav[0]+5-t.width/2)*o-r*(1-o)/2,(l[n].areav[1]+5+i-t.height/2)*o):a.fillText(e,(l[n].areav[0]+5-t.width/2)*o-r*(1-o)/2,(l[n].areav[1]+5+i-t.height/2)*o):a.fillText(e,(l[n].areav[0]+5-t.width/2)*o-r*(1-o)/2,(l[n].areav[1]+5+i-t.height/2)*o)):0<l[n].area[0]&&(t.tooltip?t.tooltip.index==n?a.strokeText(e,(l[n].area[0]+5-t.width/2)*o-r*(1-o)/2,(l[n].area[1]+5+i-t.height/2)*o):a.fillText(e,(l[n].area[0]+5-t.width/2)*o-r*(1-o)/2,(l[n].area[1]+5+i-t.height/2)*o):a.fillText(e,(l[n].area[0]+5-t.width/2)*o-r*(1-o)/2,(l[n].area[1]+5+i-t.height/2)*o)),a.stroke(),a.restore()}a.restore()}function drawFunnelDataPoints(e,t,i,a){let o=4<arguments.length&&void 0!==arguments[4]?arguments[4]:1,n=assign({},{activeWidth:10,activeOpacity:.3,border:!1,borderWidth:2,borderColor:"#FFFFFF",fillOpacity:1,labelAlign:"right"},t.extra.funnel),l=(t.height-t.area[0]-t.area[2])/e.length,r={x:t.area[3]+(t.width-t.area[1]-t.area[3])/2,y:t.height-t.area[2]},s=n.activeWidth,d=Math.min((t.width-t.area[1]-t.area[3])/2-s,(t.height-t.area[0]-t.area[2])/2-s);e=getFunnelDataPoints(e,d,o),a.save(),a.translate(r.x,r.y);for(let o=0;o<e.length;o++)0==o?(t.tooltip&&t.tooltip.index==o&&(a.beginPath(),a.setFillStyle(hexToRgb(e[o].color,n.activeOpacity)),a.moveTo(-s,0),a.lineTo(-e[o].radius-s,-l),a.lineTo(e[o].radius+s,-l),a.lineTo(s,0),a.lineTo(-s,0),a.closePath(),a.fill()),e[o].funnelArea=[r.x-e[o].radius,r.y-l,r.x+e[o].radius,r.y],a.beginPath(),a.setLineWidth(n.borderWidth*t.pixelRatio),a.setStrokeStyle(n.borderColor),a.setFillStyle(hexToRgb(e[o].color,n.fillOpacity)),a.moveTo(0,0),a.lineTo(-e[o].radius,-l),a.lineTo(e[o].radius,-l),a.lineTo(0,0),a.closePath(),a.fill(),!0==n.border&&a.stroke()):(t.tooltip&&t.tooltip.index==o&&(a.beginPath(),a.setFillStyle(hexToRgb(e[o].color,n.activeOpacity)),a.moveTo(0,0),a.lineTo(-e[o-1].radius-s,0),a.lineTo(-e[o].radius-s,-l),a.lineTo(e[o].radius+s,-l),a.lineTo(e[o-1].radius+s,0),a.lineTo(0,0),a.closePath(),a.fill()),e[o].funnelArea=[r.x-e[o].radius,r.y-l*(o+1),r.x+e[o].radius,r.y-l*o],a.beginPath(),a.setLineWidth(n.borderWidth*t.pixelRatio),a.setStrokeStyle(n.borderColor),a.setFillStyle(hexToRgb(e[o].color,n.fillOpacity)),a.moveTo(0,0),a.lineTo(-e[o-1].radius,0),a.lineTo(-e[o].radius,-l),a.lineTo(e[o].radius,-l),a.lineTo(e[o-1].radius,0),a.lineTo(0,0),a.closePath(),a.fill(),!0==n.border&&a.stroke()),a.translate(0,-l);return a.restore(),!1!==t.dataLabel&&1===o&&drawFunnelText(e,t,a,l,n.labelAlign,s,r),{center:r,radius:d,series:e}}function drawFunnelText(e,t,a,o,n,l,r){var s=Math.PI;for(let d=0;d<e.length;d++){let i,h,x,c,p=e[d],g=p.format?p.format(+p._proportion_.toFixed(2)):util.toFixed(100*p._proportion_)+"%";"right"==n?(i=0==d?(p.funnelArea[2]+r.x)/2:(p.funnelArea[2]+e[d-1].funnelArea[2])/2,h=i+2*l,x=p.funnelArea[1]+o/2,c=p.textSize||t.fontSize,a.setLineWidth(1*t.pixelRatio),a.setStrokeStyle(p.color),a.setFillStyle(p.color),a.beginPath(),a.moveTo(i,x),a.lineTo(h,x),a.stroke(),a.closePath(),a.beginPath(),a.moveTo(h,x),a.arc(h,x,2,0,2*s),a.closePath(),a.fill(),a.beginPath(),a.setFontSize(c),a.setFillStyle(p.textColor||"#666666"),a.fillText(g,h+5,x+c/2-2),a.closePath(),a.stroke(),a.closePath()):(i=0==d?(p.funnelArea[0]+r.x)/2:(p.funnelArea[0]+e[d-1].funnelArea[0])/2,h=i-2*l,x=p.funnelArea[1]+o/2,c=p.textSize||t.fontSize,a.setLineWidth(1*t.pixelRatio),a.setStrokeStyle(p.color),a.setFillStyle(p.color),a.beginPath(),a.moveTo(i,x),a.lineTo(h,x),a.stroke(),a.closePath(),a.beginPath(),a.moveTo(h,x),a.arc(h,x,2,0,2*s),a.closePath(),a.fill(),a.beginPath(),a.setFontSize(c),a.setFillStyle(p.textColor||"#666666"),a.fillText(g,h-5-measureText(g),x+c/2-2),a.closePath(),a.stroke(),a.closePath())}}function drawCanvas(e,t){t.draw()}var Timing={easeIn:function(e){return Math.pow(e,3)},easeOut:function(e){return Math.pow(e-1,3)+1},easeInOut:function(e){var t=Math.pow;return 1>(e/=.5)?.5*t(e,3):.5*(t(e-2,3)+2)},linear:function(e){return e}};function Animation(e){this.isStop=!1,e.duration="undefined"==typeof e.duration?1e3:e.duration,e.timing=e.timing||"linear";var t=function(){return"undefined"==typeof setTimeout?"undefined"==typeof requestAnimationFrame?function(e){e(null)}:requestAnimationFrame:function(e,t){setTimeout(function(){var t=+new Date;e(t)},t)}}(),i=null,a=function(o){if(null===o||!0===this.isStop)return e.onProcess&&e.onProcess(1),void(e.onAnimationFinish&&e.onAnimationFinish());if(null===i&&(i=o),o-i<e.duration){var n=(o-i)/e.duration,l=Timing[e.timing];n=l(n),e.onProcess&&e.onProcess(n),t(a,17)}else e.onProcess&&e.onProcess(1),e.onAnimationFinish&&e.onAnimationFinish()};a=a.bind(this),t(a,17)}Animation.prototype.stop=function(){this.isStop=!0};function drawCharts(e,t,a,i){var o=this,n=t.series,l=t.categories;n=fillSeries(n,t,a);var r=t.animation?t.duration:0;o.animationInstance&&o.animationInstance.stop();var s=null;if("candle"==e){let e=assign({},t.extra.candle.average);e.show?(s=calCandleMA(e.day,e.name,e.color,n[0].data),s=fillSeries(s,t,a),t.seriesMA=s):t.seriesMA?s=t.seriesMA=fillSeries(t.seriesMA,t,a):s=n}else s=n;t._series_=n=filterSeries(n),t.area=[,,,,];for(let o=0;4>o;o++)t.area[o]=t.padding[o];var d=calLegendData(s,t,a,t.chartData),h=d.area.wholeHeight,x=d.area.wholeWidth;switch(t.legend.position){case"top":t.area[0]+=h;break;case"bottom":t.area[2]+=h;break;case"left":t.area[3]+=x;break;case"right":t.area[1]+=x;}let c={},p=0;if("line"===t.type||"column"===t.type||"area"===t.type||"mix"===t.type||"candle"===t.type){if(c=calYAxisData(n,t,a),p=c.yAxisWidth,t.yAxis.showTitle){let e=0;for(let o=0;o<t.yAxis.data.length;o++)e=Math.max(e,t.yAxis.data[o].titleFontSize?t.yAxis.data[o].titleFontSize:a.fontSize);t.area[0]+=(e+6)*t.pixelRatio}let e=0,o=0;for(let a=0;a<p.length;a++)"left"==p[a].position?(t.area[3]+=0<o?p[a].width+t.yAxis.padding:p[a].width,o+=1):(t.area[1]+=0<e?p[a].width+t.yAxis.padding:p[a].width,e+=1)}else a.yAxisWidth=p;if(t.chartData.yAxisData=c,t.categories&&t.categories.length){t.chartData.xAxisData=getXAxisPoints(t.categories,t,a);let e=calCategoriesData(t.categories,t,a,t.chartData.xAxisData.eachSpacing),i=e.xAxisHeight,o=e.angle;a.xAxisHeight=i,a._xAxisTextAngle_=o,t.area[2]+=i,t.chartData.categoriesData=e}else if("line"===t.type||"area"===t.type||"points"===t.type){t.chartData.xAxisData=calXAxisData(n,t,a),l=t.chartData.xAxisData.rangesFormat;let e=calCategoriesData(l,t,a,t.chartData.xAxisData.eachSpacing),i=e.xAxisHeight,o=e.angle;a.xAxisHeight=i,a._xAxisTextAngle_=o,t.area[2]+=i,t.chartData.categoriesData=e}else t.chartData.xAxisData={xAxisPoints:[]};if(t.enableScroll&&"right"==t.xAxis.scrollAlign&&void 0===t._scrollDistance_){let e=0,i=t.chartData.xAxisData.xAxisPoints,a=t.chartData.xAxisData.startX,n=t.chartData.xAxisData.endX,l=t.chartData.xAxisData.eachSpacing,r=l*(i.length-1);e=n-a-r,o.scrollOption={currentOffset:e,startTouchX:e,distance:0,lastMoveTime:0},t._scrollDistance_=e}switch(("pie"===e||"ring"===e||"rose"===e)&&(a._pieTextMaxLength_=!1===t.dataLabel?0:getPieTextMaxLength(s)),e){case"word":let d=assign({},{type:"normal",autoColors:!0},t.extra.word);(!0==t.updateData||null==t.updateData)&&(t.chartData.wordCloudData=getWordCloudPoint(t,d.type)),this.animationInstance=new Animation({timing:"easeInOut",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),drawWordCloudDataPoints(n,t,a,i,e),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"map":i.clearRect(0,0,t.width,t.height),drawMapDataPoints(n,t,a,i);break;case"funnel":this.animationInstance=new Animation({timing:"easeInOut",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),t.chartData.funnelData=drawFunnelDataPoints(n,t,a,i,e),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"line":this.animationInstance=new Animation({timing:"easeIn",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),drawYAxisGrid(l,t,a,i),drawXAxis(l,t,a,i);var o=drawLineDataPoints(n,t,a,i,e),r=o.xAxisPoints,s=o.calPoints,d=o.eachSpacing;t.chartData.xAxisPoints=r,t.chartData.calPoints=s,t.chartData.eachSpacing=d,drawYAxis(n,t,a,i),!1!==t.enableMarkLine&&1===e&&drawMarkLine(t,a,i),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e,d,r),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"mix":this.animationInstance=new Animation({timing:"easeIn",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),drawYAxisGrid(l,t,a,i),drawXAxis(l,t,a,i);var o=drawMixDataPoints(n,t,a,i,e),r=o.xAxisPoints,s=o.calPoints,d=o.eachSpacing;t.chartData.xAxisPoints=r,t.chartData.calPoints=s,t.chartData.eachSpacing=d,drawYAxis(n,t,a,i),!1!==t.enableMarkLine&&1===e&&drawMarkLine(t,a,i),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e,d,r),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"column":this.animationInstance=new Animation({timing:"easeIn",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),drawYAxisGrid(l,t,a,i),drawXAxis(l,t,a,i);var o=drawColumnDataPoints(n,t,a,i,e),r=o.xAxisPoints,s=o.calPoints,d=o.eachSpacing;t.chartData.xAxisPoints=r,t.chartData.calPoints=s,t.chartData.eachSpacing=d,drawYAxis(n,t,a,i),!1!==t.enableMarkLine&&1===e&&drawMarkLine(t,a,i),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e,d,r),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"area":this.animationInstance=new Animation({timing:"easeIn",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),drawYAxisGrid(l,t,a,i),drawXAxis(l,t,a,i);var o=drawAreaDataPoints(n,t,a,i,e),r=o.xAxisPoints,s=o.calPoints,d=o.eachSpacing;t.chartData.xAxisPoints=r,t.chartData.calPoints=s,t.chartData.eachSpacing=d,drawYAxis(n,t,a,i),!1!==t.enableMarkLine&&1===e&&drawMarkLine(t,a,i),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e,d,r),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"ring":case"pie":this.animationInstance=new Animation({timing:"easeInOut",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),t.chartData.pieData=drawPieDataPoints(n,t,a,i,e),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"rose":this.animationInstance=new Animation({timing:"easeInOut",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),t.chartData.pieData=drawRoseDataPoints(n,t,a,i,e),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"radar":this.animationInstance=new Animation({timing:"easeInOut",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),t.chartData.radarData=drawRadarDataPoints(n,t,a,i,e),drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"arcbar":this.animationInstance=new Animation({timing:"easeInOut",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),t.chartData.arcbarData=drawArcbarDataPoints(n,t,a,i,e),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"gauge":this.animationInstance=new Animation({timing:"easeInOut",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),t.chartData.gaugeData=drawGaugeDataPoints(l,n,t,a,i,e),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});break;case"candle":this.animationInstance=new Animation({timing:"easeIn",duration:r,onProcess:function(e){i.clearRect(0,0,t.width,t.height),t.rotate&&contextRotate(i,t),drawYAxisGrid(l,t,a,i),drawXAxis(l,t,a,i);var o=drawCandleDataPoints(n,s,t,a,i,e),r=o.xAxisPoints,d=o.calPoints,h=o.eachSpacing;t.chartData.xAxisPoints=r,t.chartData.calPoints=d,t.chartData.eachSpacing=h,drawYAxis(n,t,a,i),!1!==t.enableMarkLine&&1===e&&drawMarkLine(t,a,i),s?drawLegend(s,t,a,i,t.chartData):drawLegend(t.series,t,a,i,t.chartData),drawToolTipBridge(t,a,i,e,h,r),drawCanvas(t,i)},onAnimationFinish:function(){o.event.trigger("renderComplete")}});}}function Event(){this.events={}}Event.prototype.addEventListener=function(e,t){this.events[e]=this.events[e]||[],this.events[e].push(t)},Event.prototype.trigger=function(){for(var e=arguments.length,t=Array(e),i=0;i<e;i++)t[i]=arguments[i];var a=t[0],o=t.slice(1);!this.events[a]||this.events[a].forEach(function(e){try{e.apply(null,o)}catch(t){console.error(t)}})};var Charts=function(e){e.pixelRatio=e.pixelRatio?e.pixelRatio:1,e.fontSize=e.fontSize?e.fontSize*e.pixelRatio:13*e.pixelRatio,e.title=assign({},e.title),e.subtitle=assign({},e.subtitle),e.duration=e.duration?e.duration:1e3,e.yAxis=assign({},{data:[],showTitle:!1,disabled:!1,disableGrid:!1,splitNumber:5,gridType:"solid",dashLength:4*e.pixelRatio,gridColor:"#cccccc",padding:10,fontColor:"#666666"},e.yAxis),e.yAxis.dashLength*=e.pixelRatio,e.yAxis.padding*=e.pixelRatio,e.xAxis=assign({},{rotateLabel:!1,type:"calibration",gridType:"solid",dashLength:4,scrollAlign:"left",boundaryGap:"center",axisLine:!0,axisLineColor:"#cccccc"},e.xAxis),e.xAxis.dashLength*=e.pixelRatio,e.legend=assign({},{show:!0,position:"bottom",float:"center",backgroundColor:"rgba(0,0,0,0)",borderColor:"rgba(0,0,0,0)",borderWidth:0,padding:5,margin:5,itemGap:10,fontSize:e.fontSize,lineHeight:e.fontSize,fontColor:"#333333",format:{},hiddenColor:"#CECECE"},e.legend),e.legend.borderWidth*=e.pixelRatio,e.legend.itemGap*=e.pixelRatio,e.legend.padding*=e.pixelRatio,e.legend.margin*=e.pixelRatio,e.extra=assign({},e.extra),e.rotate=!!e.rotate,e.animation=!!e.animation,e.rotate=!!e.rotate;let t=JSON.parse(JSON.stringify(config));if(t.colors=e.colors?e.colors:t.colors,t.yAxisTitleWidth=!0!==e.yAxis.disabled&&e.yAxis.title?t.yAxisTitleWidth:0,("pie"==e.type||"ring"==e.type)&&(t.pieChartLinePadding=!1===e.dataLabel?0:e.extra.pie.labelWidth*e.pixelRatio||t.pieChartLinePadding*e.pixelRatio),"rose"==e.type&&(t.pieChartLinePadding=!1===e.dataLabel?0:e.extra.rose.labelWidth*e.pixelRatio||t.pieChartLinePadding*e.pixelRatio),t.pieChartTextPadding=!1===e.dataLabel?0:t.pieChartTextPadding*e.pixelRatio,t.yAxisSplit=e.yAxis.splitNumber?e.yAxis.splitNumber:config.yAxisSplit,t.rotate=e.rotate,e.rotate){let t=e.width,i=e.height;e.width=i,e.height=t}e.padding=e.padding?e.padding:t.padding;for(let t=0;4>t;t++)e.padding[t]*=e.pixelRatio;t.yAxisWidth=config.yAxisWidth*e.pixelRatio,t.xAxisHeight=config.xAxisHeight*e.pixelRatio,e.enableScroll&&e.xAxis.scrollShow&&(t.xAxisHeight+=6*e.pixelRatio),t.xAxisLineHeight=config.xAxisLineHeight*e.pixelRatio,t.fontSize=e.fontSize,t.titleFontSize=config.titleFontSize*e.pixelRatio,t.subtitleFontSize=config.subtitleFontSize*e.pixelRatio,t.toolTipPadding=config.toolTipPadding*e.pixelRatio,t.toolTipLineHeight=config.toolTipLineHeight*e.pixelRatio,t.columePadding=config.columePadding*e.pixelRatio,e.$this=e.$this?e.$this:this,this.context=uni.createCanvasContext(e.canvasId,e.$this),e.chartData={},this.event=new Event,this.scrollOption={currentOffset:0,startTouchX:0,distance:0,lastMoveTime:0},this.opts=e,this.config=t,drawCharts.call(this,e.type,e,t,this.context)};Charts.prototype.updateData=function(){let e=0<arguments.length&&arguments[0]!==void 0?arguments[0]:{};this.opts=assign({},this.opts,e),this.opts.updateData=!0;let t=e.scrollPosition||"current";switch(t){case"current":this.opts._scrollDistance_=this.scrollOption.currentOffset;break;case"left":this.opts._scrollDistance_=0,this.scrollOption={currentOffset:0,startTouchX:0,distance:0,lastMoveTime:0};break;case"right":let e=calYAxisData(this.opts.series,this.opts,this.config),i=e.yAxisWidth;this.config.yAxisWidth=i;let a=0,o=getXAxisPoints(this.opts.categories,this.opts,this.config),n=o.xAxisPoints,l=o.startX,r=o.endX,s=o.eachSpacing,d=s*(n.length-1);a=r-l-d,this.scrollOption={currentOffset:a,startTouchX:a,distance:0,lastMoveTime:0},this.opts._scrollDistance_=a;}drawCharts.call(this,this.opts.type,this.opts,this.config,this.context)},Charts.prototype.zoom=function(){var e=Math.round,t=0<arguments.length&&void 0!==arguments[0]?arguments[0]:this.opts.xAxis.itemCount;if(!0!==this.opts.enableScroll)return void console.log("\u8BF7\u542F\u7528\u6EDA\u52A8\u6761\u540E\u4F7F\u7528\uFF01");let i=e(Math.abs(this.scrollOption.currentOffset)/this.opts.chartData.eachSpacing)+e(this.opts.xAxis.itemCount/2);this.opts.animation=!1,this.opts.xAxis.itemCount=t.itemCount;let a=calYAxisData(this.opts.series,this.opts,this.config),o=a.yAxisWidth;this.config.yAxisWidth=o;let n=0,l=getXAxisPoints(this.opts.categories,this.opts,this.config),r=l.xAxisPoints,s=l.startX,d=l.endX,h=l.eachSpacing,x=d-s,c=x-h*(r.length-1);n=x/2-h*i,0<n&&(n=0),n<c&&(n=c),this.scrollOption={currentOffset:n,startTouchX:n,distance:0,lastMoveTime:0},this.opts._scrollDistance_=n,drawCharts.call(this,this.opts.type,this.opts,this.config,this.context)},Charts.prototype.stopAnimation=function(){this.animationInstance&&this.animationInstance.stop()},Charts.prototype.addEventListener=function(e,t){this.event.addEventListener(e,t)},Charts.prototype.getCurrentDataIndex=function(t){var e=null;if(e=t.changedTouches?t.changedTouches[0]:t.mp.changedTouches[0],e){let i=getTouches(e,this.opts,t);return"pie"===this.opts.type||"ring"===this.opts.type||"rose"===this.opts.type?findPieChartCurrentIndex({x:i.x,y:i.y},this.opts.chartData.pieData):"radar"===this.opts.type?findRadarChartCurrentIndex({x:i.x,y:i.y},this.opts.chartData.radarData,this.opts.categories.length):"funnel"===this.opts.type?findFunnelChartCurrentIndex({x:i.x,y:i.y},this.opts.chartData.funnelData):"map"===this.opts.type?findMapChartCurrentIndex({x:i.x,y:i.y},this.opts):"word"===this.opts.type?findWordChartCurrentIndex({x:i.x,y:i.y},this.opts.chartData.wordCloudData):findCurrentIndex({x:i.x,y:i.y},this.opts.chartData.calPoints,this.opts,this.config,Math.abs(this.scrollOption.currentOffset))}return-1},Charts.prototype.getLegendDataIndex=function(t){var e=null;if(e=t.changedTouches?t.changedTouches[0]:t.mp.changedTouches[0],e){let i=getTouches(e,this.opts,t);return findLegendIndex({x:i.x,y:i.y},this.opts.chartData.legendData)}return-1},Charts.prototype.touchLegend=function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},i=null;if(i=t.changedTouches?t.changedTouches[0]:t.mp.changedTouches[0],i){var a=getTouches(i,this.opts,t),o=this.getLegendDataIndex(t);0<=o&&(this.opts.series[o].show=!this.opts.series[o].show,this.opts.animation=!!e.animation,this.opts._scrollDistance_=this.scrollOption.currentOffset,drawCharts.call(this,this.opts.type,this.opts,this.config,this.context))}},Charts.prototype.showToolTip=function(t){var e=1<arguments.length&&arguments[1]!==void 0?arguments[1]:{},i=null;i=t.changedTouches?t.changedTouches[0]:t.mp.changedTouches[0],i||console.log("touchError");var a=getTouches(i,this.opts,t),o=this.scrollOption.currentOffset,n=assign({},this.opts,{_scrollDistance_:o,animation:!1});if("line"===this.opts.type||"area"===this.opts.type||"column"===this.opts.type){var l=this.getCurrentDataIndex(t);if(-1<l){var r=getSeriesDataItem(this.opts.series,l);if(0!==r.length){var s=getToolTipData(r,this.opts.chartData.calPoints,l,this.opts.categories,e),d=s.textList,h=s.offset;h.y=a.y,n.tooltip={textList:d,offset:h,option:e,index:l}}}drawCharts.call(this,n.type,n,this.config,this.context)}if("mix"===this.opts.type){var l=this.getCurrentDataIndex(t);if(-1<l){var o=this.scrollOption.currentOffset,n=assign({},this.opts,{_scrollDistance_:o,animation:!1}),r=getSeriesDataItem(this.opts.series,l);if(0!==r.length){var x=getMixToolTipData(r,this.opts.chartData.calPoints,l,this.opts.categories,e),d=x.textList,h=x.offset;h.y=a.y,n.tooltip={textList:d,offset:h,option:e,index:l}}}drawCharts.call(this,n.type,n,this.config,this.context)}if("candle"===this.opts.type){var l=this.getCurrentDataIndex(t);if(-1<l){var o=this.scrollOption.currentOffset,n=assign({},this.opts,{_scrollDistance_:o,animation:!1}),r=getSeriesDataItem(this.opts.series,l);if(0!==r.length){var s=getCandleToolTipData(this.opts.series[0].data,r,this.opts.chartData.calPoints,l,this.opts.categories,this.opts.extra.candle,e),d=s.textList,h=s.offset;h.y=a.y,n.tooltip={textList:d,offset:h,option:e,index:l}}}drawCharts.call(this,n.type,n,this.config,this.context)}if("pie"===this.opts.type||"ring"===this.opts.type||"rose"===this.opts.type||"funnel"===this.opts.type){var l=this.getCurrentDataIndex(t);if(-1<l){var o=this.scrollOption.currentOffset,n=assign({},this.opts,{_scrollDistance_:o,animation:!1}),r=this.opts._series_[l],d=[{text:e.format?e.format(r):r.name+": "+r.data,color:r.color}],h={x:a.x,y:a.y};n.tooltip={textList:d,offset:h,option:e,index:l}}drawCharts.call(this,n.type,n,this.config,this.context)}if("map"===this.opts.type||"word"===this.opts.type){var l=this.getCurrentDataIndex(t);if(-1<l){var o=this.scrollOption.currentOffset,n=assign({},this.opts,{_scrollDistance_:o,animation:!1}),r=this.opts._series_[l],d=[{text:e.format?e.format(r):r.properties.name,color:r.color}],h={x:a.x,y:a.y};n.tooltip={textList:d,offset:h,option:e,index:l}}n.updateData=!1,drawCharts.call(this,n.type,n,this.config,this.context)}if("radar"===this.opts.type){var l=this.getCurrentDataIndex(t);if(-1<l){var o=this.scrollOption.currentOffset,n=assign({},this.opts,{_scrollDistance_:o,animation:!1}),r=getSeriesDataItem(this.opts.series,l);if(0!==r.length){var d=r.map(function(t){return{text:e.format?e.format(t):t.name+": "+t.data,color:t.color}}),h={x:a.x,y:a.y};n.tooltip={textList:d,offset:h,option:e,index:l}}}drawCharts.call(this,n.type,n,this.config,this.context)}},Charts.prototype.translate=function(e){this.scrollOption={currentOffset:e,startTouchX:e,distance:0,lastMoveTime:0};let t=assign({},this.opts,{_scrollDistance_:e,animation:!1});drawCharts.call(this,this.opts.type,t,this.config,this.context)},Charts.prototype.scrollStart=function(t){var e=null;e=t.changedTouches?t.changedTouches[0]:t.mp.changedTouches[0];var i=getTouches(e,this.opts,t);e&&!0===this.opts.enableScroll&&(this.scrollOption.startTouchX=i.x)},Charts.prototype.scroll=function(t){0===this.scrollOption.lastMoveTime&&(this.scrollOption.lastMoveTime=Date.now());let e=this.opts.extra.touchMoveLimit||20,i=Date.now(),a=i-this.scrollOption.lastMoveTime;if(!(a<Math.floor(1e3/e))){this.scrollOption.lastMoveTime=i;var o=null;if(o=t.changedTouches?t.changedTouches[0]:t.mp.changedTouches[0],o&&!0===this.opts.enableScroll){var n,l=getTouches(o,this.opts,t);n=l.x-this.scrollOption.startTouchX;var r=this.scrollOption.currentOffset,s=calValidDistance(this,r+n,this.opts.chartData,this.config,this.opts);this.scrollOption.distance=n=s-r;var d=assign({},this.opts,{_scrollDistance_:r+n,animation:!1});return drawCharts.call(this,d.type,d,this.config,this.context),r+n}}},Charts.prototype.scrollEnd=function(){if(!0===this.opts.enableScroll){var e=this.scrollOption,t=e.currentOffset,i=e.distance;this.scrollOption.currentOffset=t+i,this.scrollOption.distance=0}},"object"==typeof module&&"object"==typeof module.exports&&(module.exports=Charts);
\ No newline at end of file
diff --git a/pages/sub_tabbar/active.vue b/pages/sub_tabbar/active.vue
new file mode 100644
index 0000000..3dfd6b1
--- /dev/null
+++ b/pages/sub_tabbar/active.vue
@@ -0,0 +1,398 @@
+<template>
+	<view class="active">
+		<view class="active-item" v-for="(v,i) in list" :key="i">
+			<view class="active-item-title">
+				<view class="active-item-title-box"></view>
+				<text>{{v.name}}</text>
+			</view>
+			<view class="active-item-con" v-if="v.name !='积分任务'">
+				<scroll-view class="scroll-view_H" scroll-x="true" @scrolltolower="getMoreItems(i)">
+					<view class="active-item-con-item" v-for="(item,index) in v.list" :key="index" :style="{'background-image':'url('+background[i].list[index%2===0?0:1].src+')'}">
+						<text class="active-item-con-item-name">{{item.title}}</text>
+						<!-- <text class="active-item-con-item-name" v-if="v.code =='OfflineActivities'" style="opacity: 0;">暂无</text> -->
+						<view class="active-item-con-item-btn" @click="toUrl('/pages/sub_index/activeDetails/index?id='+ item.articleno + '&type=' + v.code)"><text>查看详情</text></view>
+						<!-- <view class="active-item-con-item-btn" @click="toUrl('/pages/activeDetails/index?id='+ item.articleno + '&type=' + v.code)" v-if="v.code =='OfflineActivities'"><text>查看详情</text></view> -->
+					</view>
+				</scroll-view>
+			</view>
+
+			<u-empty text="暂无活动" mode="data" v-if="v.list.length ==0"></u-empty>
+			<!-- <view class="active-item-no"  >暂无活动</view> -->
+			<view class="active-item-integral" v-if="v.name =='积分任务'">
+				<view class="active-item-integral-item" v-for="(item,index) in v.list" :key="index">
+					<view class="active-item-integral-item-left">
+						<u-image :src="item.imgSrc" width="80rpx" mode="widthFix"></u-image>
+						<view class="active-item-integral-item-left-desc">
+							<text class="active-item-integral-item-left-desc-name">{{item.taskname?item.taskname:errList[index].taskname}}</text>
+							<text class="active-item-integral-item-left-desc-desc">{{item.desc?item.desc:'暂无'}}</text>
+						</view>
+					</view>
+					<view :class=" item.isFinish?'active-item-integral-item-btnc':'active-item-integral-item-btn'" @click="item.isFinish?'':getIntegral(item)">{{item.transtatus?item.transtatus:'未完成'}}</view>
+				</view>
+			</view>
+		</view>
+		<!-- <u-gap height="70"></u-gap> -->
+		<u-tabbar :list="vuex_tabbar" :mid-button="true" active-color="#2FA8E1" inactive-color="#999999" @change="changeTabbar"></u-tabbar>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				list: [{
+						name: "线上活动",
+						code: "OnlineActivities",
+						list: []
+					},
+					{
+						name: "线下活动",
+						code: "OfflineActivities",
+						list: []
+					},
+					{
+						name: "积分任务",
+						list: [{
+								imgSrc: "/static/images/active/mrlfl.png",
+								isFinish: false
+							},
+							{
+								imgSrc: "/static/images/active/sfrzhb.png",
+								isFinish: false
+							}, {
+								imgSrc: "/static/images/active/scxfhb.png",
+								isFinish: false
+							},
+							{
+								imgSrc: "/static/images/active/scdhjf.png",
+								isFinish: false
+							},
+						]
+					}
+				],
+				background: [{
+						list: [{
+								// src: "/static/images/active/bannar3.png",
+								src: ''
+							},
+							{
+								// src: "/static/images/active/bannar4.png",
+								src: ''
+							}
+						]
+					}, {
+						list: [{
+								// src: "/static/images/active/bannar1.png",
+								src: ''
+							},
+							{
+								// src: "/static/images/active/bannar2.png",
+								src: ''
+							}
+						]
+					}
+
+				],
+				errList: [{
+						imgSrc: "/static/images/active/mrlfl.png",
+						isFinish: false,
+						taskname: "每日签到"
+					},
+					{
+						imgSrc: "/static/images/active/sfrzhb.png",
+						isFinish: false,
+						taskname: "身份认证"
+					}, {
+						imgSrc: "/static/images/active/scxfhb.png",
+						isFinish: false,
+						taskname: "首次消费"
+					},
+					{
+						imgSrc: "/static/images/active/scdhjf.png",
+						isFinish: false,
+						taskname: "首次兑换积分"
+					},
+				],
+				pagenoOn: 1,
+				pagenoOff: 1,
+				totalPageOn: "",
+				totalPageOff: ""
+			}
+		},
+		onShow() {
+			let that = this
+			// #ifdef APP-PLUS
+			let stopShowTwice = uni.getStorageSync("stopShowTwice")
+			if (stopShowTwice) {
+				return false
+			}
+			// #endif
+			let token = uni.getStorageSync('token')
+			that.pagenoOn = 1
+			that.list[0].list = []
+			that.pagenoOff = 1
+			that.list[1].list = []
+			that.getActivity(1, "OnlineActivities")
+			that.getActivity(1, "OfflineActivities")
+			// #ifdef APP-PLUS
+			uni.setStorageSync("stopShowTwice", true)
+			// #endif
+			if (token) {
+				that.getIntegralStatus()
+			}
+		},
+		methods: {
+			getActivity(no, code) {
+				let that = this
+				let pagesize = 4
+				let params = [{
+					code: code, //OnlineActivities、OfflineActivities、PopularActivities
+					pagesize: pagesize,
+					pageno: no
+				}]
+				that.$u.post("/i/activity", params).then(res => {
+					let list = res.data[0].articles.list
+					let totalPage = res.data[0].articles.totalPage
+					if (code == "OnlineActivities") {
+						that.totalPageOn = totalPage
+						that.list[0].list = that.list[0].list.concat(list)
+					} else if (code == "OfflineActivities") {
+						that.totalPageOff = totalPage
+						that.list[1].list = that.list[1].list.concat(list)
+					}
+				})
+			},
+			getMoreItems(index) {
+				let that = this
+				//console.log(index)
+				if (index === 0) {
+					let pageno = ++that.pagenoOn
+					that.pagenoOn = pageno
+					//console.log(pageno,that.totalPageOn)
+					if (pageno <= that.totalPageOn) {
+						that.getActivity(pageno, "OnlineActivities")
+					}
+				} else {
+					let pageno = ++that.pagenoOff
+					that.pagenoOff = pageno
+					if (pageno <= that.totalPageOff) {
+						that.getActivity(pageno, "OfflineActivities")
+					}
+				}
+
+			},
+			getIntegralStatus() {
+				let that = this
+				that.$u.get('v1/point/taskstatus', {}).then(res => {
+					let list = that.list[2].list
+					let reslist = res.data
+					//undone 未做   done未领取  received 已领取
+					list = list.map((item, index) => {
+						reslist[index].desc = '可获得' + reslist[index].points + '积分'
+						if (reslist[index].status == 'done') {
+							reslist[index].transtatus = index ? '领取' : '已签到'
+							item.isFinish = index ? false : true
+						} else if (reslist[index].status == 'undone') {
+							reslist[index].transtatus = index ? '去完成' : '签到'
+							item.isFinish = false
+						} else if (reslist[index].status == 'received') {
+							reslist[index].transtatus = index ? '已领取' : '已签到'
+							item.isFinish = true
+						}
+						return { ...item,
+							...reslist[index]
+						}
+					})
+
+					that.list[2].list = list
+				})
+			},
+			getIntegral(item) {
+				let that = this
+				if(item.status == 'undone' && item.taskcode  != 'signin'){
+					uni.showToast({
+						icon: "none",
+						title: "此任务暂时无法完成",
+						duration: 1500
+					})
+					return
+				}
+				//console.log(item.taskcode)
+				if (item.taskcode == 'signin') {
+					that.$u.post('v1/point/task/' + item.taskcode, {}).then(res => {
+						uni.showToast({
+							icon: "none",
+							title: "签到成功",
+							duration: 1500
+						})
+						that.getIntegralStatus()
+					})
+				} else if (item.taskcode == 'auth' || item.taskcode == 'consume') {
+					that.$u.post('v1/point/task/' + item.taskcode, {}).then(res => {
+						uni.showToast({
+							icon: "none",
+							title: "领取成功",
+							duration: 1500
+						})
+						that.getIntegralStatus()
+					})
+				} else {
+					uni.showToast({
+						icon: "none",
+						title: "此积分任务暂未开放",
+						duration: 1500
+					})
+				}
+			},
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	page {
+		background-color: #FFFFFF;
+	}
+
+	.scroll-view_H {
+		white-space: nowrap;
+		width: 100%;
+	}
+
+	.active {
+		padding: 0 30rpx;
+		font-family: "PingFang-SC-Medium";
+		background-color: #FFFFFF;
+		overflow: hidden;
+
+		&-item {
+			display: flex;
+			width: 100%;
+			flex-direction: column;
+			margin: 30rpx 0;
+
+			&-title {
+				display: flex;
+				align-items: center;
+				margin-bottom: 30rpx;
+
+				&-box {
+					width: 6rpx;
+					height: 30rpx;
+					background-image: linear-gradient(#7DD2F9, #30A8E1);
+					margin-right: 20rpx;
+				}
+
+				text {
+					font-size: 32rpx;
+					color: #343434;
+				}
+			}
+
+			&-no {
+				display: flex;
+				justify-content: center;
+				font-size: 40rpx;
+				font-weight: bold;
+				padding: 50rpx 0;
+			}
+
+			&-con {
+				// display: flex;
+				// justify-content: space-between;
+				width: 100%;
+
+				&-item {
+					border-radius: 20rpx;
+					width: 48%;
+					padding: 30rpx;
+					// background-image: url(../../static/images/active/bannar1.png);
+					background-position: center;
+					background-size: cover;
+					background-repeat: no-repeat;
+					overflow: hidden;
+					// display: flex;
+					flex-direction: column;
+					display: inline-flex;
+					margin: auto 1%;
+
+					&-name {
+						width: 100%;
+						color: #FFFFFF;
+						font-size: 31rpx;
+						white-space: nowrap;
+						text-overflow: ellipsis;
+						overflow: hidden;
+					}
+
+					&-btn {
+						margin-top: 30rpx;
+						color: #FFFFFF;
+						display: flex;
+						justify-content: center;
+						align-items: center;
+						padding: 10rpx;
+						font-size: 25rpx;
+						border-radius: 50rpx;
+						border-width: 1rpx;
+						border-style: solid;
+						border-color: #ffffff;
+						width: 150rpx;
+					}
+				}
+			}
+
+			&-integral {
+				&-item {
+					display: flex;
+					justify-content: space-between;
+					align-items: center;
+					margin-bottom: 30rpx;
+
+					&-left {
+						display: flex;
+						align-items: center;
+
+						&-desc {
+							display: flex;
+							// align-items: center;
+							flex-direction: column;
+							margin-left: 10rpx;
+
+							&-name {
+								color: #343434;
+								font-size: 32rpx;
+							}
+
+							&-desc {
+								color: #9A9A9A;
+								font-size: 25rpx;
+							}
+						}
+					}
+
+					&-btn {
+						background-color: #30A8E1;
+						color: #FFFFFF;
+						border-radius: 50rpx;
+						padding: 10rpx 30rpx;
+						font-family: "PingFang-SC-Regular";
+						font-size: 28rpx;
+						width: 150rpx;
+						text-align: center;
+					}
+
+					&-btnc {
+						background-color: #63CEFF;
+						color: #FFFFFF;
+						border-radius: 50rpx;
+						padding: 10rpx 30rpx;
+						font-family: "PingFang-SC-Regular";
+						font-size: 28rpx;
+						width: 150rpx;
+						text-align: center;
+					}
+				}
+			}
+		}
+	}
+</style>
diff --git a/pages/sub_tabbar/index.vue b/pages/sub_tabbar/index.vue
new file mode 100644
index 0000000..b410b23
--- /dev/null
+++ b/pages/sub_tabbar/index.vue
@@ -0,0 +1,528 @@
+<template>
+	<view class="wrap">
+		<!-- 头部导航 -->
+		<u-sticky h5-nav-height="0">
+			<!-- #ifndef MP-WEIXIN -->
+			<view class="status_bar"></view>
+			<!-- #endif -->
+			<view class="wrap-header">
+				<view class="img-box" @click="scan">
+					<u-image src="/static/images/index/scan.png" width="40rpx" height="40rpx" mode="aspectFit"></u-image>
+				</view>
+				<u-search placeholder="暂无服务可查询" v-model="searchVal" :show-action="false" bg-color="#F7F7F7" margin="0 15rpx"
+				 @search="search"></u-search>
+				<view class="img-box" @click="toPath('/pages/sub_index/qrcode/index')">
+					<u-image src="/static/images/index/money.png" width="40rpx" height="40rpx" mode="aspectFit"></u-image>
+				</view>
+				<view class="img-box" @click="toPath('')">
+					<u-image src="/static/images/index/square.png" width="40rpx" height="40rpx" mode="aspectFit"></u-image>
+				</view>
+			</view>
+		</u-sticky>
+		<!-- bannar内容 -->
+		<view class="wrap-bannar">
+			<view class="wrap-bannar-title">
+				<text>城市服务</text>
+				<text>一键速享</text>
+			</view>
+			<view class="wrap-bannar-box">
+				<image src="/static/images/index/bannar.png" mode="widthFix"></image>
+				<view class="wrap-bannar-box-overtitle">
+					<text>出行缴费</text>
+					<text>自在随心</text>
+				</view>
+			</view>
+		</view>
+		<!-- 功能列表 -->
+		<view class="wrap-func">
+			<u-image src="/static/images/index/bannar1.png" width="100%" mode="widthFix" border-radius="10"></u-image>
+			<!-- <view class="wrap-func-item" v-for="(v,i) in funcList" :key="i" @click="toPath()">
+				<u-image :src="v.src" width="70rpx" height="70rpx" mode="aspectFit"></u-image>
+				<text>{{v.title}}</text>
+			</view> -->
+		</view>
+		<!--热门活动 -->
+		<view class="wrap-active">
+			<text class="wrap-active-title">热门活动</text>
+			<view class="wrap-active-bannar">
+				<!-- <u-image src="/static/images/index/bannar01.png" width="100%" mode="widthFix"></u-image> -->
+				<u-swiper :list="activeImgList" name="picid" img-mode="scaleToFill" height="170" interval="5000" duration="1500"
+				 @click="activeImg"></u-swiper>
+			</view>
+			<view class="wrap-active-con">
+				<view class="wrap-active-con-item" @click="signin">
+					<u-image src="/static/images/index/mrqd.png" width="70rpx" height="70rpx"></u-image>
+					<view class="wrap-active-con-item-desc">
+						<text class="wrap-active-con-item-desc-title">每日签到</text>
+						<text class="wrap-active-con-item-desc-desc">签到即可领积分</text>
+					</view>
+				</view>
+				<view class="wrap-active-con-item" @click="toUrl('/pages/sub_index/activeDetails/index?id='+ activity.articleno + '&type=' + activity.code)">
+					<u-image src="/static/images/index/smkhd.png" width="70rpx" height="70rpx"></u-image>
+					<view class="wrap-active-con-item-desc">
+						<text class="wrap-active-con-item-desc-title">{{activity.title?activity.title:''}}</text>
+						<text class="wrap-active-con-item-desc-desc">{{activity.subtitle?activity.subtitle:'暂无'}}</text>
+					</view>
+				</view>
+				<view class="wrap-active-con-item" @click="toPath('/pages/sub_tabbar/active')">
+					<u-image src="/static/images/index/more.png" width="70rpx" height="70rpx"></u-image>
+					<view class="wrap-active-con-item-desc">
+						<text class="wrap-active-con-item-desc-title">更多活动</text>
+					</view>
+				</view>
+			</view>
+		</view>
+		<!-- 市民卡业务 -->
+		<view class="wrap-service">
+			<text class="wrap-service-title">市民卡业务</text>
+			<view class="wrap-service-con">
+				<view class="wrap-service-con-exp" @click="toUrl('/pages/sub_index/introduce/index')">
+					<u-image src="/static/images/index/smkjj.png" width="100%" mode="widthFix"></u-image>
+					<text class="wrap-service-con-exp-desc">市民卡简介</text>
+				</view>
+				<view class="wrap-service-con-box">
+					<view class="wrap-service-con-box-bl">
+						<u-image src="/static/images/index/bl.png" width="100%" mode="widthFix"></u-image>
+						<view class="wrap-service-con-box-bl-over" @click="toPath('/pages/sub_index/getCityCard/index')">
+							<text class="wrap-service-con-box-bl-over-up">办理</text>
+							<text class="wrap-service-con-box-bl-over-dowm">网络快速办理</text>
+						</view>
+					</view>
+					<view class="wrap-service-con-box-bl">
+						<u-image src="/static/images/index/zx.png" width="100%" mode="widthFix"></u-image>
+						<view class="wrap-service-con-box-bl-over" @click="toPath('/pages/sub_index/chat/index')">
+							<text class="wrap-service-con-box-bl-over-up">咨询</text>
+							<text class="wrap-service-con-box-bl-over-dowm">24小时在线咨询</text>
+						</view>
+					</view>
+				</view>
+			</view>
+		</view>
+		<!-- 底部tabbar -->
+		<!-- <u-gap height="70"></u-gap> -->
+		<u-tabbar :list="vuex_tabbar" :mid-button="true" active-color="#2FA8E1" inactive-color="#999999" @change="changeTabbar"></u-tabbar>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				searchVal: "",
+				funcList: [{
+					title: "物业缴费",
+					src: "/static/images/index/wyjf.png"
+				}, {
+					title: "电费",
+					src: "/static/images/index/df.png"
+				}, {
+					title: "加油卡充值",
+					src: "/static/images/index/jykcz.png"
+				}, {
+					title: "宽带费",
+					src: "/static/images/index/kdf.png"
+				}, {
+					title: "手机缴费",
+					src: "/static/images/index/sjjf.png"
+				}, {
+					title: "固话充值",
+					src: "/static/images/index/ghcz.png"
+				}, {
+					title: "违章查询",
+					src: "/static/images/index/wzcx.png"
+				}, {
+					title: "全部",
+					src: "/static/images/index/all.png"
+				}],
+				activity: [],
+				activeImgList: [{
+					picid: "/static/images/index/bannar01.png",
+					articleno: '00000003'
+				}, ]
+			}
+		},
+		onShow() {
+			this.getActivityList()
+		},
+		methods: {
+			search(e) {
+				uni.showToast({
+					icon: "none",
+					title: "搜索服务功能暂未开通",
+					duration: 1500
+				})
+			},
+
+			scan() {
+				let that = this
+				// #ifndef H5
+				// 只允许通过相机扫码
+				uni.scanCode({
+					// onlyFromCamera: true,
+					// scanType: ['qrCode',"barCode","datamatrix","pdf417"],
+					success: function(res) {
+						//uni.vibrate({})
+						//console.log('条码类型:' + res.scanType);
+						//console.log('条码内容:' + res.result);
+						let url = res.result
+						uni.showToast({
+							title: "扫描成功",
+							icon: "none",
+							duration: 800,
+							complete() {
+								// setTimeout(() => {
+								// 	uni.navigateTo({
+								// 		url: "/pages/sub_index/scanView/index?url=" + url
+								// 	})
+								// }, 1500)
+								let param = {
+									url: url
+								}
+								that.$u.get('/v1/qrcode/auth', param).then(ret => {
+									if (ret.data.permit) {
+										if (ret.data.action == 'water') {
+											setTimeout(() => {
+												uni.navigateTo({
+													url: "/pages/sub_index/scanView/index?url=" + ret.data.url
+												})
+											}, 1500)
+										} else if (ret.data.action == 'dlsmkh5') {
+											// #ifdef APP-PLUS
+												let token = uni.getStorageSync('token')
+												let wv = plus.webview.create(ret.data.url, 'webview_pay', {
+													backButtonAutoControl:'close',
+													additionalHttpHeaders: {
+														Authorization: 'Bearer ' + token
+													}
+												})
+												setTimeout(() => {
+													wv.show()
+												}, 1500)
+											// #endif
+											// #ifndef APP-PLUS
+											uni.showToast({
+												icon: "none",
+												title: "只支持app端",
+												duration: 1500
+											})
+											// #endif
+										}
+									} else {
+										uni.showToast({
+											icon: "none",
+											title: "暂不支持此二维码",
+											duration: 1500
+										})
+									}
+								})
+							}
+						})
+					}
+				});
+				// #endif
+				// #ifdef H5
+				uni.showToast({
+					icon: "none",
+					title: "H5不支持此功能",
+					duration: 1500
+				})
+				// #endif
+			},
+			getActivityList() {
+				let that = this
+				let param = [{
+					code: "PopularActivities", //OnlineActivities、OfflineActivities、PopularActivities
+					pagesize: 1,
+					pageno: 1
+				}]
+				that.$u.post("/i/activity", param).then(res => {
+					if (res.data[0].articles.list.length > 0) {
+						let list = res.data[0].articles.list[0]
+						list.code = 'PopularActivities'
+						that.activity = list
+					}
+				})
+			},
+			activeImg(index) {
+				let that = this
+				let obj = that.activeImgList[index]
+				uni.navigateTo({
+					url: '/pages/sub_index/activeDetails/index?id=' + obj.articleno
+				})
+			},
+			getBannarList() {
+				let that = this
+				that.$u.get('i/column/banner', {}).then(res => {
+					if (res.data.length > 0) {
+						that.activeImgList = res.data
+						//console.log(that.activeImgList)
+					}
+				}).catch(res => {
+					//console.log(1)
+				})
+			},
+			signin() {
+				let that = this
+				that.$u.post('v1/point/task/signin', {}).then(res => {
+					uni.showToast({
+						icon: "none",
+						title: "签到成功",
+						duration: 1500
+					})
+				})
+			}
+		},
+		onLoad() {
+			this.getBannarList()
+			// #ifdef APP-PLUS
+			//引入插件
+			const KJJPush = uni.requireNativePlugin('KJ-JPush');
+			let uid = uni.getStorageSync("uid")
+			//设置Alias
+			KJJPush.setAlias(uid ? uid : 'tourist', 1, result => {
+				//console.log("setAlias:" + JSON.stringify(result));
+			});
+
+			// #endif
+
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	/* #ifdef MP-WEIXIN */
+	.wrap-func {
+		/deep/image {
+			display: block;
+		}
+	}
+
+	/* #endif */
+
+	.status_bar {
+		background-color: #FFFFFF;
+	}
+
+	.wrap {
+		background-color: #FFFFFF;
+
+		&-header {
+			display: flex;
+			flex-direction: row;
+			align-items: center;
+			justify-content: space-between;
+			padding: 10rpx 15rpx;
+			background-color: #FFFFFF;
+
+			image {
+				width: 50rpx;
+				height: 50rpx;
+			}
+
+			.img-box {
+				display: flex;
+				justify-content: center;
+				align-items: center;
+				padding: 0 15rpx;
+			}
+		}
+
+		&-bannar {
+			width: 100vw;
+			margin-top: 10rpx;
+
+			&-title {
+				width: 300rpx;
+				margin: auto;
+				display: flex;
+				justify-content: space-between;
+				font-size: 35rpx;
+				font-weight: bold;
+				font-style: oblique;
+				font-family: "PingFang-SC-Bold";
+			}
+
+			image {
+				width: 100%;
+			}
+
+			&-box {
+				position: relative;
+
+				&-overtitle {
+					position: absolute;
+					width: 250rpx;
+					background-color: #ECECEC;
+					padding: 10rpx 20rpx;
+					border-radius: 50rpx;
+					top: 20rpx;
+					left: 50%;
+					transform: translate(-50%, 0);
+					display: flex;
+					font-size: 24rpx;
+					justify-content: space-between;
+					color: #808080;
+					letter-spacing: 2rpx;
+					font-family: "PingFang-SC-Medium";
+				}
+			}
+		}
+
+		&-func {
+			width: 95vw;
+			background-color: #FFFFFF;
+			margin: -180rpx auto 0;
+			// display: flex;
+			// flex-wrap: wrap;
+			// justify-content: space-between;
+			// padding: 30rpx 0;
+			border-radius: 10rpx;
+			box-shadow: 0 0rpx 6rpx #808080;
+			position: relative;
+
+			/deep/uni-image {
+				display: block;
+			}
+
+			&-item {
+				width: 25%;
+				display: flex;
+				flex-direction: column;
+				align-items: center;
+				margin-bottom: 30rpx;
+
+				text {
+					margin-top: 10rpx;
+					color: #333333;
+					font-family: "PingFang-SC-Medium";
+					font-size: 24rpx;
+				}
+			}
+		}
+
+		&-active {
+			margin-top: 30rpx;
+			padding: 0 2.5vw;
+
+			&-title {
+				font-family: "PingFang-SC-Medium";
+				font-size: 30rpx;
+				color: #333333;
+			}
+
+			&-bannar {
+				margin-top: 20rpx;
+			}
+
+			&-con {
+				display: flex;
+				justify-content: space-between;
+				margin-top: 20rpx;
+
+				// align-items: center;
+				&-item {
+					width: 32%;
+					display: flex;
+					flex-direction: column;
+					align-items: center;
+					background-color: #F7F7F7;
+					padding: 50rpx 20rpx 30rpx;
+					border-radius: 10rpx;
+
+					&-desc {
+						display: flex;
+						flex-direction: column;
+						align-items: center;
+						margin-top: 50rpx;
+						width: 100%;
+						text-align: center;
+
+						&-desc {
+							width: 100%;
+							color: #666666;
+							font-size: 20rpx;
+							margin-top: 10rpx;
+							overflow: hidden;
+							text-overflow: ellipsis;
+							white-space: nowrap;
+						}
+
+						&-title {
+							width: 100%;
+							font-family: "PingFang-SC-Medium";
+							font-size: 26rpx;
+							color: #333333;
+							overflow: hidden;
+							text-overflow: ellipsis;
+							white-space: nowrap;
+						}
+					}
+				}
+			}
+		}
+
+		&-service {
+			margin-top: 30rpx;
+			padding: 0 2.5vw;
+
+			&-title {
+				font-family: "PingFang-SC-Medium";
+				font-size: 30rpx;
+				color: #333333;
+			}
+
+			&-con {
+				display: flex;
+				flex-direction: row;
+				justify-content: space-between;
+				margin-top: 20rpx;
+
+				&-exp {
+					position: relative;
+					width: 50%;
+
+					&-desc {
+						position: absolute;
+						top: 30rpx;
+						left: 30rpx;
+						font-family: "PingFang-SC-Medium";
+						color: #FFFFFF;
+						font-size: 36rpx;
+					}
+				}
+
+				&-box {
+					width: 49%;
+					display: flex;
+					flex-direction: column;
+
+					&-bl {
+						position: relative;
+						margin-top: -10rpx;
+
+						&-over {
+							display: flex;
+							flex-direction: column;
+							position: absolute;
+							top: 50%;
+							left: 15%;
+							transform: translateY(-50%);
+
+							&-up {
+								font-family: "PingFang-SC-Medium";
+								font-size: 30rpx;
+							}
+
+							&-dowm {
+								font-family: "PingFang-SC-Medium";
+								font-size: 24rpx;
+								color: #999999;
+							}
+						}
+					}
+				}
+			}
+
+		}
+	}
+</style>
diff --git a/pages/sub_tabbar/life.vue b/pages/sub_tabbar/life.vue
new file mode 100644
index 0000000..a03c0f9
--- /dev/null
+++ b/pages/sub_tabbar/life.vue
@@ -0,0 +1,69 @@
+<template>
+	<view class="life">
+		<!-- <view class="life-con">
+			<u-empty text="功能暂未开放" mode="permission"></u-empty>
+		</view> -->
+		<view class="life-ul">
+			<view class="life-ul-item" v-for="(v,i) in list" :key="i">
+				<text>{{v.name}}</text>
+				<u-image :src="v.src" mode="widthFix" width="100%"></u-image>
+			</view>
+		</view>
+		<!-- <u-gap height="70"></u-gap> -->
+		<u-tabbar :list="vuex_tabbar" :mid-button="true" active-color="#2FA8E1" inactive-color="#999999" @change="changeTabbar"></u-tabbar>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				list:[{
+					name:'洱海',
+					src:'/static/images/life/erhai.jpg'
+				},
+				{
+					name:'丽江',
+					src:'/static/images/life/lijiang.jpg'
+				},
+				{
+					name:'香格里拉',
+					src:'/static/images/life/xianggelila.jpg'
+				},
+				{
+					name:'玉龙雪山',
+					src:'/static/images/life/yulongxueshan.jpg'
+				}]
+			}
+		},
+		methods: {
+
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.life{
+		padding: 30rpx;
+		overflow: hidden;
+		&-con{
+			margin-top: 30vh;
+			display: flex;
+			justify-content: center;
+			font-size: 50rpx;
+			font-family: "PingFang-SC-Medium";
+		}
+		&-ul{
+			&-item{
+				margin-bottom: 30rpx;
+				text{
+					display: block;
+					margin-bottom: 20rpx;
+					font-size: 36rpx;
+					font-weight: bold;
+				}
+			}
+		}
+	}
+	
+</style>
diff --git a/pages/sub_tabbar/mine.vue b/pages/sub_tabbar/mine.vue
new file mode 100644
index 0000000..25aca57
--- /dev/null
+++ b/pages/sub_tabbar/mine.vue
@@ -0,0 +1,236 @@
+<template>
+	<view class="wrap">
+		<view class="wrap-mine">
+			<!-- 头部 -->
+			<view class="wrap-mine-header" @click="toPath('/pages/sub_mine/personalMsg/index')">
+				<!-- #ifndef MP-WEIXIN -->
+				<u-navbar title="我的" :background="background" title-color="#ffffff" :border-bottom="false" :is-back="false"></u-navbar>
+				<!-- #endif -->
+				<view class="wrap-mine-header-con">
+					<view class="wrap-mine-header-con-avatar">
+						<u-avatar src="" mode="circle" size="130"></u-avatar>
+					</view>
+					<view class="wrap-mine-header-con-desc">
+						<text class="wrap-mine-header-con-desc-name">{{name?name:"游客"}}</text>
+						<text class="wrap-mine-header-con-desc-tel">{{tel?tel:'暂无手机号'}}</text>
+					</view>
+				</view>
+			</view>
+			<!-- 列表 -->
+			<view class="wrap-list">
+				<u-cell-group :border="false">
+					<u-cell-item :title="v.name" :title-style="titleStyle" :value="i===0?value:''" @click="toPath(v.path)" v-for="(v,i) in list"
+					 :key="i">
+						<u-icon :name="v.icon" custom-prefix="custom-icon" size="40" slot="icon" color="#2FA8E1"></u-icon>
+					</u-cell-item>
+				</u-cell-group>
+			</view>
+			<u-button @click="exit" :custom-style="loginOut">{{outText}}</u-button>
+		</view>
+		<!-- <u-gap height="70"></u-gap> -->
+		<u-tabbar :list="vuex_tabbar" :mid-button="true" active-color="#2FA8E1" inactive-color="#999999" @change="changeTabbar"></u-tabbar>
+	</view>
+</template>
+
+<script>
+	export default {
+		data() {
+			return {
+				outText:"",
+				tel: "暂无",
+				name: "暂无",
+				background: {
+					'background': 'no'
+				},
+				titleStyle: {
+					'font-family': 'PingFang-SC-Medium',
+					'fontSize': '28rpx',
+					'marginLeft': '30rpx'
+				},
+				value: "0积分",
+				list: [{
+						name: "我的积分",
+						path: "/pages/sub_mine/integral/index",
+						icon: "integral"
+					},
+					{
+						name: "我的足迹",
+						path: "/pages/sub_mine/cashFlow/index",
+						icon: "bills"
+					},
+					{
+						name: "我的卡券",
+						path: "/pages/sub_mine/voucher/index",
+						icon: "voucher"
+					},
+					{
+						name: "账户安全",
+						path: "/pages/sub_mine/accountSafe/index",
+						icon: "safe"
+					},
+					{
+						name: "我的消息",
+						path: "/pages/sub_mine/message/index",
+						icon: "message"
+					},
+					{
+						name: "留言反馈",
+						path: "/pages/sub_mine/leaveMsg/index",
+						icon: "leaveMsg"
+					},
+				],
+				loginOut: {
+					width: '600rpx',
+					padding: '50rpx 0',
+					marginTop: '100rpx',
+					color:'#ffffff',
+					backgroundColor:'#2FA8E1'
+				}
+			}
+		},
+		computed: {
+
+		},
+		onLoad() {
+			let that = this
+			let token = uni.getStorageSync("token")
+			if(token){
+				that.outText = "登出"
+				that.loginOut.backgroundColor = "#fa3534"
+				that.tel = uni.getStorageSync("phoneX")
+				that.name = uni.getStorageSync("name")?uni.getStorageSync("name"):'用户'
+			}else{
+				that.outText = "去登陆"
+				that.loginOut.backgroundColor = "#2FA8E1"
+				that.tel = '暂无号码'
+				that.name = '游客'
+			}
+		},
+		methods: {	
+			exit() {
+				let token = uni.getStorageSync("token")
+				if(token){
+					uni.showModal({
+						title: "提示",
+						content: "登出将清除您的本地缓存(包括手势密码、指纹等),确定要登出吗?",
+						cancelText: "取消",
+						confirmText: "确定",
+						success(res) {
+							if (res.confirm) {
+								uni.clearStorageSync()
+								setTimeout(() => {
+									uni.reLaunch({
+										url: "/pages/sub_basic/login/index"
+									})
+								}, 1500)
+							}
+						}
+					})
+				}else{
+					uni.showToast({
+						icon: "none",
+						title: "即将去往登录页",
+						duration: 1500,
+						mask:true,
+						complete() {
+							setTimeout(() => {
+								uni.reLaunch({
+									url: "/pages/sub_basic/login/index"
+								})
+							}, 1500)
+						}
+					})
+				}
+			},
+			getIntegral(){
+				let that = this
+				that.$u.get("/v1/point/total",{}).then(res=>{
+					that.value = res.data + '积分'
+				})
+			}
+		},
+		onShow(){
+			let that = this
+			let token = uni.getStorageSync('token')
+			if( token ){
+				that.getIntegral()
+			}
+		}
+	}
+</script>
+
+<style lang="scss" scoped>
+	.status_bar {
+		background-color: #4EB4E4;
+	}
+
+	.loginOut {
+		width: 600rpx;
+		padding: 50rpx 0;
+		margin-top: 100rpx;
+	}
+	
+	.wrap {
+		font-family: "PingFang-SC-Medium";
+		&-mine {
+			&-header {
+				background-image: url();
+				background-position: center;
+				background-size: cover;
+				background-repeat: no-repeat;
+				display: flex;
+				padding: 150rpx 0 80rpx;
+				&-con {
+					display: flex;
+					align-items: center;
+					margin-left: 60rpx;
+
+					&-avatar {
+						width: 130rpx;
+						height: 130rpx;
+						background-color: #FFFFFF;
+						border-radius: 50%;
+						display: flex;
+						justify-content: center;
+						align-items: center;
+						margin-right: 30rpx;
+					}
+
+					&-desc {
+						display: flex;
+						flex-direction: column;
+						color: #FFFFFF;
+
+						&-name {
+							font-size: 34rpx;
+							margin-bottom: 20rpx;
+						}
+
+						&-tel {
+							font-size: 28rpx;
+						}
+					}
+				}
+
+				&-title {
+					position: absolute;
+					left: 50%;
+					top: 30rpx;
+					transform: translateX(-50%);
+					font-size: 30rpx;
+					color: #FFFFFF;
+				}
+			}
+		}
+
+		&-list {
+			margin-top: -10rpx;
+		}
+
+	}
+	/* #ifdef MP-WEIXIN */
+	.wrap-mine-header{
+		padding: 80rpx 0 80rpx;
+	}
+	/* #endif */
+</style>
diff --git a/pages/sub_tabbar/qrcode.vue b/pages/sub_tabbar/qrcode.vue
new file mode 100644
index 0000000..9d139b2
--- /dev/null
+++ b/pages/sub_tabbar/qrcode.vue
@@ -0,0 +1,262 @@
+<template>
+	<view class="qrcode">
+		<!-- #ifndef MP-WEIXIN -->
+		<u-navbar title="我的码" :border-bottom="false" :is-back="false" :background="background" title-color="#ffffff"></u-navbar>
+		<!-- #endif -->
+		<view class="qrcode-con">
+			<u-notice-bar mode="horizontal" :list="list" bg-color="none" color="#ffffff"></u-notice-bar>
+			<view class="qrcode-con-canvas">
+				<view class="qrcode-con-canvas-toast">
+					<text>温馨提示:二维码对准闸机扫码进站</text>
+				</view>
+				<view class="qrcode-con-canvas-con" v-if="show">
+					<canvas canvas-id="qrcode" style="width: 250px;height: 250px;"  />
+				</view>
+				<view class="qrcode-con-canvas-nocon" v-if="!show">
+					<u-empty text="暂无二维码" mode="list" icon-size="200"></u-empty>
+				</view>
+				<text style="color: #999999;margin-top: 30rpx;">二维码每15s刷新一次</text>
+				<view class="qrcode-con-canvas-reflash" @click="isSigned">
+					<u-icon name="reflash" color="#666666" size="40" custom-prefix="custom-icon" label="刷新" label-size="34"></u-icon>
+				</view>
+				<!-- <view class="qrcode-con-canvas-line"></view>
+				<view class="qrcode-con-canvas-footer">
+					<view class="qrcode-con-canvas-footer-item" @click="toPath('')">
+						<view class="qrcode-con-canvas-footer-item-img">
+							<u-image src="/static/images/busQrcode/cklx.png" width="50rpx" height="50rpx" mode="aspectFit"></u-image>
+						</view>
+						<text class="qrcode-con-canvas-footer-item-text">路线查询</text>
+					</view>
+					<view class="qrcode-con-canvas-footer-item">
+						<view class="qrcode-con-canvas-footer-item-img" @click="toPath('')">
+							<u-image src="/static/images/busQrcode/ccjl.png" width="50rpx" height="50rpx" mode="aspectFit"></u-image>
+						</view>
+						<text class="qrcode-con-canvas-footer-item-text">乘车记录</text>
+					</view>
+				</view> -->
+			</view>
+		</view>
+		<!-- <u-gap height="70"></u-gap> -->
+		<u-tabbar :list="vuex_tabbar" :mid-button="true" inactive-color="#999999" active-color="#2FA8E1" @change="changeTabbar"></u-tabbar>
+	</view>
+</template>
+
+<script>
+	import uQRCode from '@/static/js/uqrcode.js'
+	const app = getApp()
+	export default {
+		data() {
+			return {
+				val: "",
+				list: ["欢迎使用大理市民卡!"],
+				background: {
+					'background': 'no'
+				},
+				show: "",
+				setInter: ""
+			}
+		},
+		computed: {
+
+		},
+		onLoad() {
+			let that = this
+			that.isSigned()
+			
+		},
+		methods: {
+			isSigned() {
+				let that = this
+				let token = uni.getStorageSync("token")
+				let signed = uni.getStorageSync("signed")
+				if (!token) {
+					uni.showModal({
+						title: "提示",
+						content: "您还未登录,无法使用app功能",
+						cancelText: "再等等",
+						confirmText: "去登陆",
+						success(res) {
+							if (res.confirm) {
+								uni.reLaunch({
+									url: '/pages/sub_basic/login/index'
+								})
+							}
+						}
+					})
+					return false
+				}
+				if (!signed) {
+					uni.showModal({
+						title: "提示",
+						content: "您还未绑定签约,无法使用二维码消费",
+						cancelText: "再等等",
+						confirmText: "去绑定",
+						success(res) {
+							if (res.confirm) {
+								uni.navigateTo({
+									url: "/pages/sub_mine/bindBankCard/index"
+								})
+							}
+						}
+					})
+					return false
+				}
+				that.getQrcode()
+				clearInterval(that.setInter)
+				that.setInter = setInterval(() => {
+					that.getQrcode()
+				}, 15 * 1000)
+			},
+			getQrcode() {
+				let that = this
+				let param = {
+					version:app.globalData.version
+				}
+				that.$u.post("/v1/qrcode", param).then((res) => {
+					that.show = true
+					uQRCode.make({
+						canvasId: 'qrcode',
+						componentInstance: this,
+						text: res.qrcode,
+						size: 250,
+						margin: 10,
+						backgroundColor: '#ffffff',
+						foregroundColor: '#000000',
+						fileType: 'jpg',
+						correctLevel: uQRCode.errorCorrectLevel.H,
+						success: res => {
+							// console.log(res)
+						}
+					})
+				}).catch(res => {
+					that.show = false
+				})
+			},
+		},
+		onUnload() {
+			// #ifndef H5
+			let that = this
+			clearInterval(that.setInter)
+			// #endif
+		},
+		onHide() {
+			// #ifndef H5
+			let that = this
+			clearInterval(that.setInter)
+			// #endif
+		},
+	}
+</script>
+
+<style scoped lang="scss">
+	/* #ifdef MP-WEIXIN */
+	.qrcode{
+		background-image: url();
+	}
+	/* #endif */
+	.qrcode {
+		width: 100vw;
+		height: 100vh;
+		background-position: center;
+		background-image: url(../../static/images/qrcode/bannar.png);
+		background-size: cover;
+		background-repeat: no-repeat;
+		font-family: "PingFang-SC-Medium";
+
+		&-con {
+			padding: 30rpx;
+			&-title {
+				display: flex;
+				justify-content: space-between;
+				align-items: center;
+				color: #FFFFFF;
+
+				text {
+					font-family: "PingFang-SC-Medium";
+					font-size: 32rpx;
+				}
+			}
+
+			&-toast {
+				display: flex;
+				color: #FFFFFF;
+				align-items: center;
+				margin-top: 30rpx;
+
+				&-con {
+					font-size: 28rpx;
+					margin-left: 20rpx;
+				}
+			}
+
+			&-canvas {
+				margin-top: 60rpx;
+				padding: 30rpx;
+				background-color: #FFFFFF;
+				border-radius: 20rpx;
+				display: flex;
+				flex-direction: column;
+				align-items: center;
+
+				&-toast {
+					padding: 20rpx;
+					background-color: #F0F0F0;
+					border-radius: 50rpx;
+					color: #343434;
+					font-size: 28rpx;
+				}
+
+				&-con {
+					padding: 40rpx;
+					background-color: #F0F0F0;
+					margin-top: 30rpx;
+				}
+				&-nocon{
+					padding: 40rpx;
+					margin-top: 30rpx;
+				}
+
+				&-reflash {
+					margin-top: 30rpx;
+					display: flex;
+					align-items: center;
+					color: #343434;
+					opacity: .7;
+				}
+
+				&-line {
+					width: 600rpx;
+					height: 5rpx;
+					background-color: #F0F0F0;
+					margin: 30rpx 0;
+				}
+
+				&-footer {
+					display: flex;
+					justify-content: space-around;
+					width: 600rpx;
+
+					&-item {
+						display: flex;
+						flex-direction: column;
+						align-items: center;
+						color: #343434;
+						font-size: 28rpx;
+
+						&-img {
+							width: 80rpx;
+							height: 80rpx;
+							border-radius: 50rpx;
+							background-color: #F0F0F0;
+							display: flex;
+							justify-content: center;
+							align-items: center;
+							margin-bottom: 20rpx;
+						}
+					}
+				}
+			}
+		}
+
+	}
+</style>