mirror of
https://github.com/TeamPiped/Piped.git
synced 2024-11-14 20:28:23 +00:00
edd65825f8
Time code text field no longer appears when sharing without time code. Time code text field now appears under 'share with time code' checkbox. 'playlistId' and 'playlistIndex' are no longer required props.
106 lines
3.6 KiB
Vue
106 lines
3.6 KiB
Vue
<template>
|
|
<ModalComponent>
|
|
<h2 v-t="'actions.share'" />
|
|
<div class="flex justify-between">
|
|
<label v-t="'actions.piped_link'" />
|
|
<input type="checkbox" v-model="pipedLink" @change="onChange" />
|
|
</div>
|
|
<div v-if="this.hasPlaylist" class="flex justify-between">
|
|
<label v-t="'actions.with_playlist'" />
|
|
<input type="checkbox" v-model="withPlaylist" @change="onChange" />
|
|
</div>
|
|
<div class="flex justify-between">
|
|
<label v-t="'actions.with_timecode'" for="withTimeCode" />
|
|
<input id="withTimeCode" type="checkbox" v-model="withTimeCode" @change="onChange" />
|
|
</div>
|
|
<div v-if="this.withTimeCode" class="flex justify-between mt-2">
|
|
<label v-t="'actions.time_code'" />
|
|
<input class="input w-12" type="text" v-model="timeStamp" />
|
|
</div>
|
|
<a :href="generatedLink" target="_blank">
|
|
<h3 class="mt-4" v-text="generatedLink" />
|
|
</a>
|
|
<div class="flex justify-end mt-4">
|
|
<button class="btn" v-t="'actions.follow_link'" @click="followLink()" />
|
|
<button class="btn ml-3" v-t="'actions.copy_link'" @click="copyLink()" />
|
|
</div>
|
|
</ModalComponent>
|
|
</template>
|
|
|
|
<script>
|
|
import ModalComponent from "./ModalComponent.vue";
|
|
|
|
export default {
|
|
props: {
|
|
videoId: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
currentTime: {
|
|
type: Number,
|
|
required: true,
|
|
},
|
|
playlistId: {
|
|
type: String,
|
|
},
|
|
playlistIndex: {
|
|
type: Number,
|
|
},
|
|
},
|
|
components: {
|
|
ModalComponent,
|
|
},
|
|
data() {
|
|
return {
|
|
withTimeCode: true,
|
|
pipedLink: true,
|
|
withPlaylist: true,
|
|
timeStamp: null,
|
|
hasPlaylist: false,
|
|
};
|
|
},
|
|
mounted() {
|
|
this.timeStamp = parseInt(this.currentTime);
|
|
this.withTimeCode = this.getPreferenceBoolean("shareWithTimeCode", true);
|
|
this.pipedLink = this.getPreferenceBoolean("shareAsPipedLink", true);
|
|
this.withPlaylist = this.getPreferenceBoolean("shareWithPlaylist", true);
|
|
this.hasPlaylist = this.playlistId != undefined && !isNaN(this.playlistIndex);
|
|
},
|
|
methods: {
|
|
followLink() {
|
|
window.open(this.generatedLink, "_blank").focus();
|
|
},
|
|
async copyLink() {
|
|
await this.copyURL(this.generatedLink);
|
|
},
|
|
async copyURL(mytext) {
|
|
try {
|
|
await navigator.clipboard.writeText(mytext);
|
|
alert(this.$t("info.copied"));
|
|
} catch ($e) {
|
|
alert(this.$t("info.cannot_copy"));
|
|
}
|
|
},
|
|
onChange() {
|
|
this.setPreference("shareWithTimeCode", this.withTimeCode, true);
|
|
this.setPreference("shareAsPipedLink", this.pipedLink, true);
|
|
this.setPreference("shareWithPlaylist", this.withPlaylist, true);
|
|
},
|
|
},
|
|
computed: {
|
|
generatedLink() {
|
|
var baseUrl = this.pipedLink
|
|
? window.location.origin + "/watch?v=" + this.videoId
|
|
: "https://youtu.be/" + this.videoId;
|
|
var url = new URL(baseUrl);
|
|
if (this.withTimeCode && this.timeStamp > 0) url.searchParams.append("t", this.timeStamp);
|
|
if (this.hasPlaylist && this.withPlaylist) {
|
|
url.searchParams.append("list", this.playlistId);
|
|
url.searchParams.append("index", this.playlistIndex);
|
|
}
|
|
return url.href;
|
|
},
|
|
},
|
|
};
|
|
</script>
|