Skip to content

Commit

Permalink
Adds a Multiview link to the simulcasts panel on video page
Browse files Browse the repository at this point in the history
  • Loading branch information
meiamsome committed Dec 29, 2024
1 parent 20f86f5 commit e1edcd3
Show file tree
Hide file tree
Showing 2 changed files with 127 additions and 0 deletions.
118 changes: 118 additions & 0 deletions src/components/watch/WatchSideBar.vue
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,33 @@
{{ hidden[relation] ? "+" : "-" }} {{ related[relation].length }} {{ relationI18N(relation) }}
</a>
<v-spacer />
<v-tooltip
v-if="relation === 'simulcasts'"
top
>
<template #activator="{ on, attrs }">
<span v-bind="attrs" v-on="on">
<v-btn
icon
tile
:disabled="!simulcastMultiviewLink.ok"
small
class="mr-2"
:to="simulcastMultiviewLink.url"
>
<v-icon small>
{{ icons.mdiViewDashboard }}
</v-icon>
</v-btn>
</span>
</template>
<span v-if="simulcastMultiviewLink.ok">
{{ $t('component.relatedVideo.simulcasts.linkToMultiview.tooltip') }}
</span>
<span v-if="!simulcastMultiviewLink.ok">
{{ $t(`component.relatedVideo.simulcasts.linkToMultiview.error.${simulcastMultiviewLink.error.reason}`, simulcastMultiviewLink.error.i18nParameters) }}
</span>
</v-tooltip>
<v-btn
:key="`playlist-btn-${relation}`"
icon
Expand Down Expand Up @@ -100,6 +127,8 @@ import filterVideos from "@/mixins/filterVideos";
import { mdiTimerOutline } from "@mdi/js";
import { videoTemporalComparator } from "@/utils/functions";
import { musicdexURL } from "@/utils/consts";
import { decodeLayout, encodeLayout } from "@/utils/mv-utils";
import { mapState } from "vuex";
export default {
name: "WatchSideBar",
Expand Down Expand Up @@ -130,6 +159,7 @@ export default {
};
},
computed: {
...mapState("multiview", ["autoLayout"]),
// totalRelations() {
// return Object.values(this.related).map(r => r.length).reduce((a, b) => a+b);
// }
Expand Down Expand Up @@ -160,6 +190,94 @@ export default {
}
return [];
},
simulcastMultiviewLink() {
if (!this.related.simulcasts.length) {
// There's no simulcasts so let's not make a URL
return {
ok: false,
error: {
reason: "noSimulcasts",
i18nParameters: {},
},
};
}
const defaultLayoutString = this.autoLayout[this.related.simulcasts.length + 1];
if (!defaultLayoutString) {
// We do not have a default layout for the total amount of streams
// TODO: We could auto-generate a layout in this case
return {
ok: false,
error: {
reason: "noDefaultLayout",
i18nParameters: {
videoCount: this.related.simulcasts.length + 1,
},
},
};
}
const { layout, content } = decodeLayout(defaultLayoutString);
if (!layout) {
console.warn("Unable to decode the default layout.");
// TODO: We could auto-generate a layout in this case as well
return {
ok: false,
error: {
reason: "layoutBuildFailure",
i18nParameters: {},
},
};
}
const allSimulcastVideos = [
{
type: "video",
id: this.video.id,
},
...this.related.simulcasts.map((simulcast) => ({
type: "video",
id: simulcast.id,
})),
];
// Fill in blank spaces in the layout with the simulcast videos in order.
// This is for the case where the default layout already has chat boxes specified in content.
const filledContents = layout.map((_, i) => content[i] ?? allSimulcastVideos.shift());
if (allSimulcastVideos.length) {
console.warn(`Expected all videos to be placeable in default, but ${allSimulcastVideos.length} were not able to be placed.`);
return {
ok: false,
error: {
reason: "layoutBuildFailure",
i18nParameters: {},
},
};
}
const layoutURIComponent = encodeLayout({
layout,
contents: filledContents,
includeVideo: true,
});
if (!layoutURIComponent || layoutURIComponent === "error") {
console.warn("Unable to encode a layout with the filled contents.");
return {
ok: false,
error: {
reason: "layoutBuildFailure",
i18nParameters: {},
},
};
}
return {
ok: true,
url: `/multiview/${encodeURIComponent(layoutURIComponent)}`,
};
},
},
// mounted() {
// this.$nextTick(this.updateSongs);
Expand Down
9 changes: 9 additions & 0 deletions src/locales/en/ui.yml
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,15 @@ component:
relatedVideo:
clipsLabel: clips
simulcastsLabel: simulcasts
simulcasts:
linkToMultiview:
tooltip: Open all Simulcasts in Multiview
error:
layoutBuildFailure: >-
An error occurred while creating the Multiview link.
Please file a bug report for this on GitHub or via the Discord.
noDefaultLayout: Multiview does not have a layout for {videoCount} videos.
noSimulcasts: There are no simulcasts for this video.
refersLabel: refers
sourcesLabel: sources
songsLabel: songs
Expand Down

0 comments on commit e1edcd3

Please sign in to comment.