2024-02-20 08:43:28 +00:00
|
|
|
<template>
|
|
|
|
<ModalComponent @close="$emit('close')">
|
|
|
|
<div class="flex flex-col">
|
|
|
|
<h2 v-t="'actions.create_playlist'" />
|
2024-02-23 16:39:16 +00:00
|
|
|
<input v-model="playlistName" type="text" class="input mt-2" />
|
|
|
|
<div class="ml-auto mt-3 w-min flex">
|
|
|
|
<button v-t="'actions.cancel'" class="btn" @click="$emit('close')" />
|
|
|
|
<button v-t="'actions.okay'" class="btn ml-2" @click="onCreatePlaylist" />
|
2024-02-20 08:43:28 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</ModalComponent>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import ModalComponent from "./ModalComponent.vue";
|
|
|
|
|
|
|
|
export default {
|
|
|
|
components: {
|
|
|
|
ModalComponent,
|
|
|
|
},
|
|
|
|
emits: ["created", "close"],
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
playlistName: "",
|
|
|
|
};
|
|
|
|
},
|
2024-03-16 15:48:24 +00:00
|
|
|
mounted() {
|
|
|
|
window.addEventListener("keydown", this.handleKeyDown);
|
|
|
|
},
|
|
|
|
unmounted() {
|
|
|
|
window.removeEventListener("keydown", this.handleKeyDown);
|
|
|
|
},
|
2024-02-20 08:43:28 +00:00
|
|
|
methods: {
|
2024-03-16 15:48:24 +00:00
|
|
|
handleKeyDown(event) {
|
|
|
|
if (event.code === "Enter") {
|
|
|
|
this.onCreatePlaylist();
|
|
|
|
event.preventDefault();
|
|
|
|
}
|
|
|
|
},
|
2024-02-20 08:43:28 +00:00
|
|
|
onCreatePlaylist() {
|
|
|
|
if (!this.playlistName) return;
|
|
|
|
|
|
|
|
this.createPlaylist(this.playlistName).then(response => {
|
|
|
|
if (response.error) alert(response.error);
|
|
|
|
else {
|
2024-03-16 16:00:50 +00:00
|
|
|
this.$emit("created", response.playlistId, this.playlistName);
|
2024-02-20 08:43:28 +00:00
|
|
|
this.$emit("close");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|