<template>
	<view class="content">
		<view style="text-align: center;">
			<image class="logo" src="https://lihai001.oss-cn-chengdu.aliyuncs.com/def/35adb202404271727457954.png">
			</image>
			<view class="tips">欢迎登录蜀优采</view>
		</view>

		<view class='card'>
			<view style="display: flex;align-items: center;">
				<text>账号:</text>
				<up-input v-model="formData.account" placeholder="请输入账号或手机号"></up-input>
			</view>
			<view style="margin: 30rpx 0;">
			</view>
			<view style="display: flex;justify-content: space-between;align-items: center;">
				<text style="margin-right: 20rpx;">密码:</text>
				<up-input v-model="formData.password" placeholder="请输入密码" password="true"></up-input>
			</view>
		</view>
		<view class="submit-btn">
			<up-button @click="submit" color="#20B128" size="large">
				登录</up-button>

		</view>

	</view>
</template>

<script setup>
	import {
		userLoginApi,
		userInfoApi,
		getStoreInfo,
		getloginSms,
		loginUpdateUserApi
	} from "@/api/user.js";
	import {
		ref,
		reactive
	} from "vue"
	import useUserStore from "@/store/user";
	const userStore = useUserStore();




	const formData = reactive({
		account: "",
		code: "",
		password:'',
		terminal: 1,
		scene: 1
	})


	// 获取验证码
	const cutDown = ref(0)
	const flag = ref(true)
	const code = ref('')
	const checkPhone = (phone) => {
		const regex = /^1[3-9]\d{9}$/;
		return regex.test(phone) ? true : false
	}

	const getCode = async () => {
		if (!checkPhone(formData.account)) return uni.$u.toast('请输入正确的手机号')
		await getloginSms({
			account: formData.account
		})
		flag.value = false
		cutDown.value = 60
		let timer = setInterval(() => {
			cutDown.value--
			if (cutDown.value <= 0) clearInterval(timer)
		}, 1000)
	}
	// 获取验证码结束


	const zh = ref("")

	const submit = () => {
		userLoginApi({
			...formData
		}).then(res => {
			getStoreInfo().then(res => {
				uni.setStorageSync("STORE_INFO", JSON.stringify(res.data))
			})
			uni.setStorageSync('token', res.data.token);
			userStore.setToken(res.data.token);
			userInfoApi().then(res => {
				const user = res.data;
				userStore.setUserInfo(user);
				if (!user.openid) loginUpdateUserApi({
					mobile: user.mobile
				})
				uni.reLaunch({
					url: '/pages/index/index'
				}) // 存储token到本地存储中
			})
		})



	}
</script>

<style lang='scss'>
	.content {
		background-color: white;
		height: 100vh;
		box-sizing: border-box;
		padding-top: 15vh;

		.logo {
			height: 152rpx;
			width: 152rpx;
		}

		.tips {
			color: #444444;
			font-size: 28rpx;
			margin: 30rpx 0;
		}
	}

	.card {
		padding: 50rpx;
		background-color: white;
		margin-bottom: 30rpx;
		padding-bottom: 30rpx;
	}

	.submit-btn {
		position: absolute;
		bottom: 100rpx;
		width: 710rpx;
		left: 50%;
		transform: translateX(-50%);
	}

	.code-btn {
		display: flex;
		align-items: center;
	}

	.btn-text {
		color: #20B128;
	}
</style>