You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
OneAuth/oaweb/src/pages/user.vue

98 lines
2.9 KiB
Vue

<!--
* user.vue
* Copyright (C) 2023 veypi <i@veypi.com>
* 2023-10-08 05:31
* Distributed under terms of the MIT license.
-->
<template>
<div>
<h1 class="page-h1">账号设置</h1>
2 years ago
<div class="flex justify-center pt-10">
<crud ref="table" editable :keys="keys" :data="[u.local]" @update="newData = $event[0]">
<template #k_icon="{ value, set }">
<div class="w-full flex justify-center">
<uploader class="" @success="set" dir="user_icon">
<q-avatar>
<img :src="value">
</q-avatar>
</uploader>
</div>
</template>
2 years ago
<template #k_pass>
<q-btn @click="prompt = true" size='sm' color='secondary'>修改</q-btn>
</template>
2 years ago
</crud>
</div>
2 years ago
<q-dialog v-model="prompt" persistent>
<q-card style="min-width: 350px">
<q-card-section>
<div class="text-h6">请输入新密码</div>
</q-card-section>
<q-card-section class="q-pt-none">
<q-input type='password' dense v-model="pass[0]" autofocus @keyup.enter="prompt = false">
</q-input>
<q-input type='password' dense v-model="pass[1]" autofocus @keyup.enter="prompt = false">
</q-input>
</q-card-section>
<q-card-actions align="right" class="text-primary">
<q-btn flat label="取消" v-close-popup />
<q-btn flat label="确定" @click="reset" v-close-popup />
</q-card-actions>
</q-card>
</q-dialog>
2 years ago
<div v-if="newData" class="flex justify-center gap-8 mt-6">
<q-btn color="brown-5" label="回退" @click="table.reload" />
<q-btn color="deep-orange" glossy label="保存" @click="save" />
</div>
</div>
</template>
<script lang="ts" setup>
2 years ago
import msg from '@veypi/msg';
import api from 'src/boot/api';
import crud from 'src/components/crud.vue';
import uploader from 'src/components/uploader';
import { useUserStore } from 'src/stores/user';
import { ref } from 'vue';
2 years ago
let prompt = ref(false)
2 years ago
let u = useUserStore()
let table = ref()
const keys = ref<any>([
{ name: 'id', label: 'ID', editable: false },
{ name: 'username', label: '用户名' },
2 years ago
{ name: 'pass', label: '密码' },
2 years ago
{ name: 'nickname', label: '昵称' },
{ name: 'icon', label: 'logo' },
{ name: 'email', label: '邮箱' },
{ name: 'phone', label: '手机号' },
])
const newData = ref()
const save = () => {
api.user.update(u.id, newData.value).then(e => {
msg.Info('更新成功')
Object.assign(u.local, newData.value)
newData.value = null
}).catch(e => {
msg.Warn('更新失败 ' + e)
})
}
2 years ago
let pass = ref(['', ''])
const reset = () => {
if (pass.value[0] == '' || pass.value[1] == '') {
msg.Warn('密码不能为空')
return
}
if (pass.value[0] != pass.value[1]) {
msg.Warn('两次密码不一致')
return
}
}
</script>
<style scoped></style>