gamebrary/src/components/GameBoard/ListNameEdit.vue
2018-10-18 22:15:28 -07:00

82 lines
1.8 KiB
Vue

<template lang="html">
<div class="list-name">
<input
v-if="editing"
class="small"
v-model="localListName"
ref="input"
:id="`list-${listIndex}`"
@keyup.enter="save"
@keyup.esc="save"
>
<span v-else @click="edit">
{{ listName }} ({{ gameCount }})
</span>
</div>
</template>
<script>
export default {
props: {
listName: String,
listIndex: [String, Number],
gameCount: Number,
},
data() {
return {
editing: false,
localListName: '',
};
},
methods: {
handleClick(e) {
const outsideClickEvent = e.target.id !== `list-${this.listIndex}`;
const hasChanged = this.listName !== this.localListName;
if (outsideClickEvent) {
this.exit();
}
if (outsideClickEvent && hasChanged) {
this.save();
}
},
save() {
this.$store.commit('UPDATE_LIST_NAME', {
listIndex: this.listIndex,
listName: this.localListName,
});
this.$emit('update');
},
edit() {
this.editing = true;
this.localListName = this.listName;
this.$nextTick(() => {
document.addEventListener('click', this.handleClick);
this.$refs.input.focus();
});
},
exit() {
this.editing = false;
this.$nextTick(() => {
document.removeEventListener('click', this.handleClick);
});
},
},
};
</script>
<style lang="scss" rel="stylesheet/scss" scoped>
.list-name {
cursor: pointer;
}
</style>