mirror of
https://github.com/romancm/gamebrary
synced 2025-01-08 01:08:44 +00:00
82 lines
1.8 KiB
Vue
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>
|