Skip to content

Commit

Permalink
Add basic OTP handling to Entry List (subdavis#189)
Browse files Browse the repository at this point in the history
  • Loading branch information
Zachary Milonas committed Jul 25, 2018
1 parent c06e31e commit 2f3454a
Showing 1 changed file with 38 additions and 3 deletions.
41 changes: 38 additions & 3 deletions src/components/EntryListItem.vue
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@
</span>
</div>
<div class="buttons">
<span class="fa-stack otp" v-if="otp">
<i class="fa fa-circle fa-stack-2x"></i>
<i class="fa fa-clock-o fa-stack-1x fa-inverse"></i>
</span>
<span class="fa-stack copy" v-on:click="copy">
<i class="fa fa-circle fa-stack-2x"></i>
<i class="fa fa-clipboard fa-stack-1x fa-inverse"></i>
Expand All @@ -21,6 +25,8 @@
</template>
`
<script>
const OTP = require('keeweb/app/scripts/util/otp.js')
export default {
props: {
entry: Object,
Expand All @@ -38,15 +44,41 @@
'entry.view_is_active': function(val) {
if (val)
this.$el.scrollIntoView({
block: "end",
inline: "nearest",
block: "end",
inline: "nearest",
behavior: "smooth"});
}
},
data() {
return {
// OTP
otp: false,
otp_timeleft: 0,
otp_loop: undefined,
otp_value: "",
otp_height: 0
}
},
beforeDestroy(){
clearInterval(this.otp_loop)
},
methods: {
details(e) {
this.$router.route("/entry-details/" + this.entry.id)
},
setupOTP(url) {
let otpobj = OTP.parseUrl(url)
this.otp = true
let do_otp = () => {
otpobj.next((code, timeleft)=>{
this.otp_value = code;
this.otp_timeleft = (timeleft / 1000) | 0;
this.otp_height = Math.floor(timeleft / 300) + "%"
})
}
this.otp_loop = setInterval(do_otp, 2000)
do_otp()
},
autofill(e) {
e.stopPropagation()
console.log("autofill")
Expand All @@ -63,6 +95,9 @@
a.href = url
return a
}
},
mounted() {
this.setupOTP(this.unlockedState.getDecryptedAttribute(this.entry, "otp"))
}
}
</script>
Expand Down Expand Up @@ -107,4 +142,4 @@
.strike {
text-decoration: line-through;
}
</style>
</style>

0 comments on commit 2f3454a

Please sign in to comment.