1
0
mirror of https://github.com/TeamPiped/Piped.git synced 2025-01-08 02:20:29 +05:30
Piped/src/components/PlaylistAddModal.vue

116 lines
3.5 KiB
Vue
Raw Normal View History

2022-04-07 08:03:25 +05:30
<template>
<div class="modal">
<div>
<div class="modal-container">
<div class="flex">
<span class="text-2xl w-max inline-block" v-t="'actions.select_playlist'" />
<button class="ml-3" @click="$emit('close')"><font-awesome-icon icon="xmark" /></button>
</div>
2022-08-28 20:12:55 +05:30
<select class="select w-full mt-3" v-model="selectedPlaylist">
2022-04-07 08:03:25 +05:30
<option
v-for="playlist in playlists"
:value="playlist.id"
:key="playlist.id"
v-text="playlist.name"
/>
</select>
2022-08-28 20:12:55 +05:30
<div class="flex justify-end mt-3">
<button
class="btn"
@click="handleClick(selectedPlaylist)"
ref="addButton"
v-t="'actions.add_to_playlist'"
/>
</div>
2022-04-07 08:03:25 +05:30
</div>
</div>
</div>
</template>
<script>
export default {
props: {
videoId: {
type: String,
required: true,
},
},
data() {
return {
playlists: [],
selectedPlaylist: null,
processing: false,
2022-04-07 08:03:25 +05:30
};
},
mounted() {
this.fetchPlaylists();
this.selectedPlaylist = this.getPreferenceString("selectedPlaylist" + this.hashCode(this.authApiUrl()));
window.addEventListener("keydown", this.handleKeyDown);
window.blur();
},
unmounted() {
window.removeEventListener("keydown", this.handleKeyDown);
2022-04-07 08:03:25 +05:30
},
methods: {
handleKeyDown(event) {
if (event.code === "Escape") {
this.$emit("close");
} else if (event.code === "Enter") {
this.handleClick(this.selectedPlaylist);
} else return;
event.preventDefault();
},
2022-04-07 08:03:25 +05:30
handleClick(playlistId) {
if (!playlistId) {
alert(this.$t("actions.please_select_playlist"));
return;
}
if (this.processing) return;
2022-04-07 08:03:25 +05:30
this.$refs.addButton.disabled = true;
this.processing = true;
2022-04-07 08:03:25 +05:30
this.fetchJson(this.authApiUrl() + "/user/playlists/add", null, {
2022-04-07 08:03:25 +05:30
method: "POST",
body: JSON.stringify({
playlistId: playlistId,
videoId: this.videoId,
}),
headers: {
Authorization: this.getAuthToken(),
"Content-Type": "application/json",
},
}).then(json => {
this.setPreference("selectedPlaylist" + this.hashCode(this.authApiUrl()), playlistId);
2022-04-07 08:03:25 +05:30
this.$emit("close");
if (json.error) alert(json.error);
});
},
async fetchPlaylists() {
this.fetchJson(this.authApiUrl() + "/user/playlists", null, {
2022-04-07 08:03:25 +05:30
headers: {
Authorization: this.getAuthToken(),
},
}).then(json => {
this.playlists = json;
});
},
},
};
</script>
2022-08-28 20:12:55 +05:30
<style scoped>
.modal {
@apply fixed z-50 top-0 left-0 w-full h-full bg-dark-900 bg-opacity-80 transition-opacity table;
}
.modal > div {
@apply table-cell align-middle;
}
.modal-container {
@apply w-min m-auto px-8 bg-dark-700 p-6 rounded-xl;
}
</style>