Skip to content

Instantly share code, notes, and snippets.

@TrueSlu
Created February 21, 2019 17:44
Show Gist options
  • Save TrueSlu/0fccbdc17069d8efd527e78df9827a7d to your computer and use it in GitHub Desktop.
Save TrueSlu/0fccbdc17069d8efd527e78df9827a7d to your computer and use it in GitHub Desktop.
Password Reset
<div id="app">
<password-reset></password-reset>
</div>
Vue.component('password-reset', {
data: function () {
return {
password: '',
confirm: '',
userEmail: '[email protected]'
}
},
computed: {
match() {
if(this.password.length && this.confirm.length) {
return this.password == this.confirm;
} else {
return false;
}
}
},
template: `
<div class="password-wrap">
<header class="head">
<h1>Reset Password</h1>
<h4>Choose a new password for {{userEmail}}</h4>
</header>
<div class="form-wrap form">
<div class="form-row">
<header class="label">New Password</header>
<input class="input" type="password" v-model="password" />
</div>
<div class="form-row">
<header class="label">Confirm Password</header>
<input class="input" type="password" v-model="confirm" />
</div>
</div>
<footer class="foot">
<button class="btn txt-btn btn-secondary">Cancel</button>
<button :class="{'disabled' : !match}" class="btn txt-btn btn-primary">Reset Password</button>
</footer>
</div>
`
})
var vm = new Vue({
el: '#app'
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.21/vue.min.js"></script>
.password-wrap {
height: 552px;
width: 904px;
border: 1px solid rgba(17,18,21,0.1);
border-radius: 2px;
background-color: #FFFFFF;
margin: 72px auto;
.head {
text-align: center;
padding: 50px 0 80px 0;
h1 {
margin:0;
color: #111215;
font-size: 34px;
font-weight: bold;
letter-spacing: -0.5px;
line-height: 38px;
text-align: center;}
h4 {
margin:0;
color: #111215;
font-size: 20px;
font-weight: 600;
line-height: 27px;
text-align: center;
font-weight: normal;
}
}
.form-wrap {
padding: 0 72px;
}
.foot {
padding: 24px 48px 0 48px;
margin-top: 64px;
border-top: 1px solid rgba(#000, .1);
display: flex;
justify-content: space-between;
button {
height: 48px;
padding: 0 20px;
font-size: 12px;
font-weight: 600;
letter-spacing: 1.2px;
line-height: 16px;
background: none;
border: none;
&.disabled {
opacity: .65;
pointer-events: none;
}
&.btn-secondary {
text-transform: uppercase;
color: #111215;
}
&.btn-primary {
background-color: #111215;
color: #fff;
cursor: pointer;
}
}
}
}
.form-row {
display: block;
margin-bottom: 24px;
}
.label {
font-size: 12px;
font-weight: 700;
letter-spacing: 1px;
line-height: 18px;
text-transform: uppercase;
}
.form .label {
margin-bottom: 12px;
}
.input {
height: 48px;
width: 100%;
border: 1px solid rgba(17,18,21,.2);
border-radius: 2px;
background-color: #fff;
margin-bottom: 8px;
padding: 0 12px;
opacity: .8;
color: #111215;
font-size: 14px;
font-weight: 500;
letter-spacing: .1px;
line-height: 20px;
}
body {
background-color: #F5F7F7;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment