mirror of
https://github.com/XiaoDaiGua-Ray/ray-template.git
synced 2025-10-08 08:10:10 +08:00
166 lines
5.0 KiB
TypeScript
166 lines
5.0 KiB
TypeScript
/**
|
|
*
|
|
* @author Ray <https://github.com/XiaoDaiGua-Ray>
|
|
*
|
|
* @date 2023-06-20
|
|
*
|
|
* @workspace ray-template
|
|
*
|
|
* @remark 今天也是元气满满撸代码的一天
|
|
*/
|
|
|
|
/** 解锁界面 */
|
|
|
|
import { NInput, NForm, NFormItem, NButton, NFlex } from 'naive-ui'
|
|
import AppAvatar from '@/app-components/app/AppAvatar'
|
|
|
|
import dayjs from 'dayjs'
|
|
import { useSigningActions, useSettingActions } from '@/store'
|
|
import { rules, useCondition } from '@/app-components/app/AppLockScreen/shared'
|
|
import useAppLockScreen from '@/app-components/app/AppLockScreen/appLockVar'
|
|
import { useDevice } from '@/hooks'
|
|
|
|
import type { FormInst, InputInst } from 'naive-ui'
|
|
|
|
export default defineComponent({
|
|
name: 'UnlockScreen',
|
|
setup() {
|
|
const formRef = ref<FormInst | null>(null)
|
|
const inputInstRef = ref<InputInst | null>(null)
|
|
|
|
const { logout } = useSigningActions()
|
|
const { updateSettingState } = useSettingActions()
|
|
const { setLockAppScreen } = useAppLockScreen()
|
|
const { isTabletOrSmaller } = useDevice()
|
|
|
|
const HH_MM_FORMAT = 'HH:mm'
|
|
const AM_PM_FORMAT = 'A'
|
|
const YY_MM_DD_FORMAT = 'YY年MM月DD日'
|
|
const DDD_FORMAT = 'ddd'
|
|
|
|
const state = reactive({
|
|
lockCondition: useCondition(),
|
|
HH_MM: dayjs().format(HH_MM_FORMAT),
|
|
AM_PM: dayjs().locale('en').format(AM_PM_FORMAT),
|
|
YY_MM_DD: dayjs().format(YY_MM_DD_FORMAT),
|
|
DDD: dayjs().format(DDD_FORMAT),
|
|
})
|
|
const dayInterval = setInterval(() => {
|
|
state.HH_MM = dayjs().format(HH_MM_FORMAT)
|
|
state.AM_PM = dayjs().format(AM_PM_FORMAT)
|
|
}, 6_000)
|
|
const yearInterval = setInterval(() => {
|
|
state.YY_MM_DD = dayjs().format(YY_MM_DD_FORMAT)
|
|
state.DDD = dayjs().format(DDD_FORMAT)
|
|
}, 86_400_000)
|
|
|
|
/** 退出登陆并且回到登陆页 */
|
|
const backToSigning = () => {
|
|
window.$dialog.warning({
|
|
title: '警告',
|
|
content: '是否返回到登陆页?',
|
|
positiveText: '确定',
|
|
negativeText: '取消',
|
|
onPositiveClick: () => {
|
|
logout()
|
|
setTimeout(() => {
|
|
updateSettingState('lockScreenSwitch', false)
|
|
})
|
|
},
|
|
})
|
|
}
|
|
|
|
/** 解锁 */
|
|
const unlockScreen = () => {
|
|
formRef.value?.validate((error) => {
|
|
if (!error) {
|
|
setLockAppScreen(false)
|
|
updateSettingState('lockScreenSwitch', false)
|
|
|
|
state.lockCondition = useCondition()
|
|
}
|
|
})
|
|
}
|
|
|
|
onBeforeUnmount(() => {
|
|
clearInterval(dayInterval)
|
|
clearInterval(yearInterval)
|
|
})
|
|
|
|
return {
|
|
...toRefs(state),
|
|
backToSigning,
|
|
unlockScreen,
|
|
formRef,
|
|
inputInstRef,
|
|
isTabletOrSmaller,
|
|
}
|
|
},
|
|
render() {
|
|
const { isTabletOrSmaller } = this
|
|
const { HH_MM, AM_PM, YY_MM_DD, DDD } = this
|
|
const hmSplit = HH_MM.split(':')
|
|
const { unlockScreen, backToSigning } = this
|
|
|
|
return (
|
|
<div class="app-lock-screen__unlock">
|
|
<div class="app-lock-screen__unlock__content">
|
|
<div class="app-lock-screen__unlock__content-wrapper">
|
|
<div
|
|
class={[
|
|
'app-lock-screen__unlock__content-bg__wrapper',
|
|
'app-lock-screen__unlock__content-bg',
|
|
isTabletOrSmaller
|
|
? 'app-lock-screen__unlock__content-bg--smaller'
|
|
: '',
|
|
]}
|
|
>
|
|
<div class="left">{hmSplit[0]}</div>
|
|
<div class="right">{hmSplit[1]}</div>
|
|
</div>
|
|
</div>
|
|
<div class="app-lock-screen__unlock__content-avatar">
|
|
<AppAvatar avatarSize={52} style="pointer-events: none;" />
|
|
</div>
|
|
<div class="app-lock-screen__unlock__content-input">
|
|
<NForm ref="formRef" model={this.lockCondition} rules={rules}>
|
|
<NFormItem path="lockPassword">
|
|
<NInput
|
|
ref="inputInstRef"
|
|
v-model:value={this.lockCondition.lockPassword}
|
|
type="password"
|
|
placeholder="请输入解锁密码"
|
|
clearable
|
|
minlength={6}
|
|
maxlength={12}
|
|
onKeydown={(e: KeyboardEvent) => {
|
|
if (e.code === 'Enter') {
|
|
unlockScreen()
|
|
}
|
|
}}
|
|
/>
|
|
</NFormItem>
|
|
<NFlex justify="space-between">
|
|
<NButton type="primary" text onClick={backToSigning.bind(this)}>
|
|
返回登陆
|
|
</NButton>
|
|
<NButton type="primary" text onClick={unlockScreen.bind(this)}>
|
|
进入系统
|
|
</NButton>
|
|
</NFlex>
|
|
</NForm>
|
|
</div>
|
|
<div class="app-lock-screen__unlock__content-date">
|
|
<div class="current-date">
|
|
{HH_MM} <span>{AM_PM}</span>
|
|
</div>
|
|
<div class="current-year">
|
|
{YY_MM_DD} <span>{DDD}</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
)
|
|
},
|
|
})
|