<template>
	<BasicContainer ref='basicContainer' :option="option">
		<!-- 主体 -->
		<template #body>
			<view class="changePwd_main">
				<!-- 提示 -->
				<view class="tip">
					<view>
						提示
					</view>

					<view>
						密码必须是由8-16位的数字、符号、大小写字母组合(不能是纯数字)
					</view>
				</view>

				<view class="content" :style="{minHeight: details.height}">
					<view class="">
						<!-- 原密码 -->
						<view class="change_row flex-c-sb">
							<view class="input_title">
								原密码
							</view>

							<MyInput style="height: 100%;" class="flex1" v-model="details.form.oldPwd" :showPwd="true"
								placeholder="请输入旧密码" type="password" :rules="details.rules.oldPwd"
								@change="handleInputChange" />
						</view>

						<!-- 新密码 -->
						<view class="change_row flex-c-sb">
							<view class="input_title">
								新密码
							</view>

							<MyInput style="height: 100%;" class="flex1" v-model="details.form.newPwd" :showPwd="true"
								placeholder="请输入新密码" type="password" :rules="details.rules.newPwd"
								@change="handleInputChange" />
						</view>

						<!-- 确认密码 -->
						<view class="change_row flex-c-sb">
							<view class="input_title">
								确认密码
							</view>

							<MyInput style="height: 100%;" class="flex1" v-model="details.form.confirmNewPwd" :showPwd="true"
								placeholder="请再次输入新密码" type="password" :rules="details.rules.confirmNewPwd"
								@change="handleInputChange" />
						</view>

						<view class="forgetThePassword">
							忘记密码?
						</view>
					</view>

					<view class="submitButton flex-c-c" @click="handleSubmit">
						确认修改
					</view>
				</view>
			</view>
		</template>
	</BasicContainer>

	<tips ref="tip" />

	<!-- #ifdef APP -->
	<saomiao2 :ishidestop="scanState !== 0"></saomiao2>
	<!-- #endif -->
</template>



<script lang="ts" setup>
	import {
		postUpdatePwd,
	} from '@/api/user.js'
	import {
		onLoad,
		onShow,
		onHide,
	} from '@dcloudio/uni-app'
	import { nextTick, reactive, ref, toRefs } from "vue";
	import utils from '@/utils/utils.js'
	import useSystemSettingsStore from '@/store/useSystemSettingsStore';
	import { storeToRefs } from 'pinia';
	const { scanState } = storeToRefs(useSystemSettingsStore())
	// 组件配置
	const option = reactive({
		// 标题
		title: '修改密码',
		// 下拉刷新回调函数
		async pullDownRefreshInitPage() {

			return null
		},
		// 触底加载回到函数
		reachBottomInitPage: async () => { return null },
		haveData: true,
		isEnd: false,
		pageLoading: false
	})

	// 组件实例
	const basicContainer = ref() // 基础组件
	const tip = ref() // 提示组件

	let details = reactive({
		height: '70vh',
		rules: {
			oldPwd: {
				required: true,
				trigger: 'input',
				message: '请输入旧密码'
			},
			newPwd: {
				required: true,
				rulesFn(value) {
					const isNumber = utils.isNumber(value)
					if (isNumber) return false

					return /^[\u4E00-\u9FA5A-Za-z0-9_]{8,16}$/.test(value);
				},
				trigger: 'input',
				message: '密码格式错误'
			},
			confirmNewPwd: {
				required: true,
				rulesFn(value) {
					return details.form.newPwd === details.form.confirmNewPwd;
				},
				trigger: 'input',
				message: '密码不一致'
			}
		},
		form: {
			/** 旧密码 */
			oldPwd: '',
			/** 新密码 */
			newPwd: '',
			/** 确认新密码 */
			confirmNewPwd: ''
		}
	})

	onShow(async () => {
		await nextTick()
		details.height = await utils.getViewDistanceFormTop('.content')
	})

	/** 提交修改密码 */
	const handleSubmit = () => {
		if (!details.form.oldPwd) return utils.handleToast('请输入旧密码')
		if (!details.rules.newPwd.rulesFn(details.form.oldPwd)) return utils.handleToast('新密码格式错误')
		if (!details.rules.confirmNewPwd.rulesFn('')) return utils.handleToast('二次输入密码不一致')

		tip.value.setdetails({
			isshow: true,
			content: '确认提交修改密码',
			cancelTxt: '取 消',
			confirmTxt: '确 认',
			async success() {
				option.pageLoading = true
				const submitData = {
					old_password: details.form.oldPwd,
					new_password: details.form.newPwd
				}

				try {
					const res = await postUpdatePwd(submitData)

					const { code, data } = res
					if (code !== 200) return
				} catch (err) {
					console.log('err :>> ', err);
					//TODO handle the exception
				} finally {
					option.pageLoading = false

					// 关闭弹窗
					tip.value.setdetails({ isshow: false })
				}
			},
		})
	}

	const handleInputChange = (newValue, oldValue) => {
		console.log('newValue :>> ', newValue);
		console.log('oldValue :>> ', oldValue);
	};
</script>

<style lang="scss" scoped>
	@import url("@/utils/style/common.scss");

	.changePwd_main {
		.tip {
			background: #f5f5f6;
			padding: 40upx;
			color: #AFB4BA;
			font-size: 0.8rem;
			line-height: 1.5rem;
		}

		.content {
			display: flex;
			justify-content: space-between;
			flex-direction: column;
			background: #fff;
			padding: 100upx 40upx 60upx;
			box-sizing: border-box;

			// 修改行
			.change_row {
				// padding: 40upx 0 20upx;
				height: 70upx;
				padding: 40upx 0 0;
				border-bottom: 2upx solid #eee;

				.input_title {
					color: #092C4D;
					font-weight: bold;
					width: 150upx;
				}
			}

			// 忘记密码
			.forgetThePassword {
				margin-top: 60upx;
				color: var(--primaryColor);
				font-size: 0.9rem;
			}


			$btnHeight: 80upx;

			// 确认按钮
			.submitButton {
				margin-top: 60upx;
				width: 80%;
				height: $btnHeight;
				background-color: var(--subjectColor);
				color: #fff;
				margin: 0 auto;
				border-radius: calc($btnHeight / 2);
			}
		}
	}
</style>