vuepress-theme-reco/components/Password.vue

330 lines
6.9 KiB
Vue
Raw Normal View History

2019-04-15 10:35:40 +08:00
<template>
2019-05-08 14:07:15 +08:00
<div class="password-shadow" :class="{'is-home': !isPage}">
2019-11-09 02:05:06 +08:00
<!-- <Background /> -->
2019-05-05 11:18:15 +08:00
<h3 class="title">{{isPage ? $frontmatter.title : $site.title}}</h3>
<p class="description" v-if="!isPage">{{$site.description}}</p>
2019-04-15 10:35:40 +08:00
<label class="inputBox" id="box">
<input
v-model="key"
type="password"
@keyup.enter="inter"
@focus="inputFocus"
@blur="inputBlur">
<span>{{warningText}}</span>
<button ref="passwordBtn" @click="inter">OK</button>
</label>
<div class="footer">
<span>
<i class="iconfont reco-theme"></i>
2019-08-31 01:50:57 +08:00
<a target="blank" href="https://vuepress-theme-reco.recoluan.com">vuePress-theme-reco</a>
2019-04-15 10:35:40 +08:00
</span>
<span>
<i class="iconfont reco-other"></i>
2019-05-08 15:13:18 +08:00
<a>{{ $themeConfig.author || $site.title }}</a>
2019-04-15 10:35:40 +08:00
</span>
<span>
<i class="iconfont reco-copyright"></i>
<a>{{ year }}</a>
</span>
</div>
</div>
</template>
<script>
import Background from '@theme/components/Background'
export default {
2019-09-20 13:54:13 +08:00
components: { Background },
2019-05-05 11:18:15 +08:00
props: {
isPage: {
type: Boolean,
default: false
}
},
2019-04-15 10:35:40 +08:00
name: 'Password',
2019-09-20 13:54:13 +08:00
data () {
2019-04-15 10:35:40 +08:00
return {
warningText: 'Konck! Knock!',
key: ''
}
},
computed: {
year () {
return new Date().getFullYear()
}
},
methods: {
inter () {
2019-10-26 01:42:44 +08:00
const {
key,
isPage,
isHasPageKey,
isHasKey,
$refs: { passwordBtn }
} = this
const keyVal = key.trim()
const pageKey = `pageKey${window.location.pathname}`
const keyName = isPage ? pageKey : 'key'
sessionStorage.setItem(keyName, keyVal)
const isKeyTrue = isPage ? isHasPageKey() : isHasKey()
if (!isKeyTrue) {
2019-04-15 10:35:40 +08:00
this.warningText = 'Key Error'
return
2019-09-20 13:54:13 +08:00
}
2019-10-26 01:42:44 +08:00
2019-11-09 02:05:06 +08:00
const width = document.getElementById('box').style.width
2019-04-15 10:35:40 +08:00
passwordBtn.style.width = `${width - 2}px`
passwordBtn.style.opacity = 1
setTimeout(() => {
2019-09-20 13:54:13 +08:00
window.location.reload()
2019-04-15 10:35:40 +08:00
}, 800)
},
inputFocus () {
this.warningText = 'Input Your Key'
},
inputBlur () {
this.warningText = 'Konck! Knock!'
2019-10-26 01:42:44 +08:00
},
isHasKey () {
const keyPage = this.$themeConfig.keyPage
const keys = keyPage.keys
return keys && keys.indexOf(sessionStorage.getItem('key')) > -1
},
isHasPageKey () {
const pageKeys = this.$frontmatter.keys
const pageKey = `pageKey${window.location.pathname}`
return pageKeys && pageKeys.indexOf(sessionStorage.getItem(pageKey)) > -1
2019-04-15 10:35:40 +08:00
}
}
}
</script>
<style lang="stylus" scoped>
@require '../styles/recoConfig.styl'
2019-05-08 14:07:15 +08:00
.theme-container.no-sidebar
.password-shadow
padding-left 0
.password-shadow.is-home {
padding-left 0
}
2019-04-15 10:35:40 +08:00
.password-shadow {
width 100vw;
height 100vh;
position relative
2019-05-05 11:18:15 +08:00
padding-left: 20rem;
2019-10-20 22:25:57 +08:00
// background-image: radial-gradient(ellipse farthest-corner at center top,#497EC6 0,#000105 100%);
2019-04-15 10:35:40 +08:00
.title {
position: absolute;
left 0
right 0
top 12%
margin auto
text-align center
2019-09-01 20:13:13 +08:00
color $textColor
2019-04-15 10:35:40 +08:00
font-size 30px
box-sizing: border-box;
padding: 0 10px;
text-shadow $textShadow
2019-04-15 10:35:40 +08:00
}
.description {
position: absolute;
left 0
right 0
top 20%
margin auto
text-align center
2019-09-01 20:13:13 +08:00
color $textColor
2019-04-15 10:35:40 +08:00
font-size 22px
box-sizing: border-box;
padding: 0 10px;
text-shadow $textShadow
2019-04-15 10:35:40 +08:00
}
.inputBox{
max-width:700px;
height: 100px;
background: $accentColor;
border-radius: $borderRadius
2019-04-15 10:35:40 +08:00
position: absolute;
left 0
right 0
top 36%
margin auto
padding-left 20px
box-sizing border-box
opacity 0.9
input{
width:600px;
height:100%;
border:none;
padding:0;
padding-left:5px;
color: #fff;
background: none;
outline: none;
position: absolute;
bottom:0;
opacity 0
font-size 50px
&:focus {
opacity 1
}
&:focus~span{
transform: translateY(-80px);
color $accentColor
font-size 30px
opacity:0.8;
}
&:focus~button{
opacity:1;
width:100px;
}
}
span{
width:200px;
height: 100%;
display: block;
position: absolute;
line-height:100px;
top:0;
left:20px;
color: #fff;
cursor: text;
transition: 0.5s;
transform-origin: left top;
font-size 30px
}
button{
width:0px;
height:98px;
border-radius: $borderRadius
2019-04-15 10:35:40 +08:00
position: absolute;
border 1px solid $accentColor
right:1px;
top 1px
border:0;
padding:0;
background: #fff;
color: $accentColor;
font-size:18px;
outline:none;
cursor: pointer;
opacity:0;
transition: 0.5s;
z-index: 1;
}
}
.footer {
position: absolute;
left 0
right 0
bottom 10%
margin auto
padding: 2.5rem;
text-align: center;
color: lighten($textColor, 25%);
> span {
margin-left 1rem
> i {
margin-right .5rem
2019-09-20 13:54:13 +08:00
}
2019-04-15 10:35:40 +08:00
}
}
@media (max-width: $MQMobile) {
.inputBox{
max-width:700px;
height: 60px;
background: $accentColor;
border-radius: $borderRadius
2019-04-15 10:35:40 +08:00
position: absolute;
left 0
right 0
top 43%
margin auto
2019-11-09 02:05:06 +08:00
padding-left 16.4rem
2019-04-15 10:35:40 +08:00
box-sizing border-box
opacity 0.9
input{
width:600px;
height:100%;
border:none;
padding:0;
padding-left:5px;
color: #fff;
background: none;
outline: none;
position: absolute;
bottom:0;
opacity 0
font-size 30px
&:focus {
opacity 1
}
&:focus~span{
transform: translateY(-60px);
color $accentColor
font-size 20px
opacity:0.8;
}
&:focus~button{
opacity:1;
width:60px;
}
}
span{
width:200px;
height: 100%;
display: block;
position: absolute;
line-height:60px;
top:0;
left:20px;
color: #fff;
cursor: text;
transition: 0.5s;
transform-origin: left top;
font-size 20px
}
button{
width:0px;
height:58px;
border-radius: $borderRadius
2019-04-15 10:35:40 +08:00
position: absolute;
border 1px solid $accentColor
right:1px;
top 1px
border:0;
padding:0;
background: #fff;
color: $accentColor;
font-size:18px;
outline:none;
cursor: pointer;
opacity:0;
transition: 0.5s;
z-index: 1;
}
}
}
2019-11-09 02:05:06 +08:00
@media (max-width: $MQNarrow) {
.inputBox{
padding-left $mobileSidebarWidth
}
}
2019-04-15 10:35:40 +08:00
}
2019-05-05 11:18:15 +08:00
// narrow desktop / iPad
@media (max-width: $MQNarrow)
.password-shadow
padding-left $mobileSidebarWidth
2019-04-15 10:35:40 +08:00
2019-05-05 11:18:15 +08:00
// wide mobile
@media (max-width: $MQMobile)
.password-shadow
padding-left 0
</style>