Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Respect playlist sort order in watch-video-playlist #5013

Merged
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
18 commits
Select commit Hold shift + click to select a range
c07dfb9
Implement playlist sorting
kommunarr Apr 10, 2024
5c03d60
Hide sort menu for remote playlists
kommunarr Apr 10, 2024
d91792a
Remove 'Custom (descending)' sort order
kommunarr Apr 11, 2024
318fe08
Adjust sort order & align dropdown with 'More Options' button
kommunarr Apr 11, 2024
9db7e48
Make 'Latest added first' default option instead of custom
kommunarr Apr 11, 2024
95a6403
Remove unlikely-to-be-implemented 'Date published' sorting options
kommunarr Apr 11, 2024
b2b77eb
Merge branch 'development' of github.com:FreeTubeApp/FreeTube into fe…
kommunarr Apr 11, 2024
10aac78
Update to use sortOrder as main variable throughout
kommunarr Apr 11, 2024
8fd5055
Hide sort menu for playlists of length <2
kommunarr Apr 11, 2024
af09a76
Send sorted user playlist to watch-video-playlist
kommunarr Apr 13, 2024
c589aba
Merge branch 'development' of github.com:FreeTubeApp/FreeTube into fe…
kommunarr Apr 16, 2024
4028551
Merge branch 'development' of github.com:FreeTubeApp/FreeTube into fe…
kommunarr Apr 24, 2024
61a5885
Implement minor reversing optimization / cleanup
kommunarr Apr 24, 2024
1cf9f7e
Update src/renderer/helpers/playlists.js
kommunarr May 13, 2024
33399a1
Merge branch 'development' of github.com:FreeTubeApp/FreeTube into fe…
kommunarr May 22, 2024
d4124a1
Merge branch 'development' of github.com:FreeTubeApp/FreeTube into fe…
kommunarr May 22, 2024
b91d925
Change Playlist.js logic to cache user playlists, and pass the sorted…
kommunarr May 30, 2024
093c3e6
Merge branch 'development' of github.com:FreeTubeApp/FreeTube into fe…
kommunarr Jun 6, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {
untilEndOfLocalPlayList,
} from '../../helpers/api/local'
import { invidiousGetPlaylistInfo } from '../../helpers/api/invidious'
import { getSortedPlaylistItems, SORT_BY_VALUES } from '../../helpers/playlists'

export default defineComponent({
name: 'WatchVideoPlaylist',
Expand Down Expand Up @@ -153,6 +154,12 @@ export default defineComponent({
},
}
},
userPlaylistSortOrder: function () {
return this.$store.getters.getUserPlaylistSortOrder
},
sortOrder: function () {
return this.isUserPlaylist ? this.userPlaylistSortOrder : SORT_BY_VALUES.Custom
},
},
watch: {
userPlaylistsReady: function() {
Expand Down Expand Up @@ -471,21 +478,15 @@ export default defineComponent({
this.channelName = ''
this.channelId = ''

if (this.playlistItems.length === 0 || allowPlayingVideoRemoval) {
this.playlistItems = playlist.videos
} else {
// `this.currentVideo` relies on `playlistItems`
const latestPlaylistContainsCurrentVideo = playlist.videos.some(v => v.playlistItemId === this.playlistItemId)
// Only update list of videos if latest video list still contains currently playing video
if (latestPlaylistContainsCurrentVideo) {
this.playlistItems = playlist.videos
}
}

if (this.reversePlaylist) {
this.playlistItems = this.playlistItems.toReversed()
// Don't update list of videos if allowPlayingVideoRemoval is false
// and the latest video list does not contain the currently playing video
if (this.playlistItems.length > 0 && !allowPlayingVideoRemoval &&
!playlist.videos.some(v => v.playlistItemId === this.playlistItemId)) {
this.isLoading = false
return
}

this.playlistItems = getSortedPlaylistItems(playlist.videos, this.sortOrder, this.currentLocale, this.reversePlaylist)
this.isLoading = false
},

Expand Down
41 changes: 41 additions & 0 deletions src/renderer/helpers/playlists.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
export const SORT_BY_VALUES = {
DateAddedNewest: 'date_added_descending',
DateAddedOldest: 'date_added_ascending',
AuthorAscending: 'author_ascending',
AuthorDescending: 'author_descending',
VideoTitleAscending: 'video_title_ascending',
VideoTitleDescending: 'video_title_descending',
Custom: 'custom'
}

export function getSortedPlaylistItems(playlistItems, sortOrder, locale, reversed = false) {
if (sortOrder === SORT_BY_VALUES.Custom) {
return reversed ? playlistItems.toReversed() : playlistItems
}

return playlistItems.toSorted((a, b) => {
const first = !reversed ? a : b
const second = !reversed ? b : a
return compareTwoPlaylistItems(first, second, sortOrder, locale)
})
}

function compareTwoPlaylistItems(a, b, sortOrder, locale) {
switch (sortOrder) {
case SORT_BY_VALUES.DateAddedNewest:
return b.timeAdded - a.timeAdded
case SORT_BY_VALUES.DateAddedOldest:
return a.timeAdded - b.timeAdded
case SORT_BY_VALUES.VideoTitleAscending:
return a.title.localeCompare(b.title, locale)
case SORT_BY_VALUES.VideoTitleDescending:
return b.title.localeCompare(a.title, locale)
case SORT_BY_VALUES.AuthorAscending:
return a.author.localeCompare(b.author, locale)
case SORT_BY_VALUES.AuthorDescending:
return b.author.localeCompare(a.author, locale)
kommunarr marked this conversation as resolved.
Show resolved Hide resolved
default:
console.error(`Unknown sortOrder: ${sortOrder}`)
return 0
}
}
35 changes: 2 additions & 33 deletions src/renderer/views/Playlist/Playlist.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,16 +16,7 @@ import {
} from '../../helpers/api/local'
import { extractNumberFromString, setPublishedTimestampsInvidious, showToast } from '../../helpers/utils'
import { invidiousGetPlaylistInfo, youtubeImageUrlToInvidious } from '../../helpers/api/invidious'

const SORT_BY_VALUES = {
DateAddedNewest: 'date_added_descending',
DateAddedOldest: 'date_added_ascending',
AuthorAscending: 'author_ascending',
AuthorDescending: 'author_descending',
VideoTitleAscending: 'video_title_ascending',
VideoTitleDescending: 'video_title_descending',
Custom: 'custom',
}
import { getSortedPlaylistItems, SORT_BY_VALUES } from '../../helpers/playlists'

export default defineComponent({
name: 'Playlist',
Expand Down Expand Up @@ -176,29 +167,7 @@ export default defineComponent({
return this.sortOrder === SORT_BY_VALUES.Custom
},
sortedPlaylistItems: function () {
if (this.sortOrder === SORT_BY_VALUES.Custom) {
return this.playlistItems
}

return this.playlistItems.toSorted((a, b) => {
switch (this.sortOrder) {
case SORT_BY_VALUES.DateAddedNewest:
return b.timeAdded - a.timeAdded
case SORT_BY_VALUES.DateAddedOldest:
return a.timeAdded - b.timeAdded
case SORT_BY_VALUES.VideoTitleAscending:
return a.title.localeCompare(b.title, this.currentLocale)
case SORT_BY_VALUES.VideoTitleDescending:
return b.title.localeCompare(a.title, this.currentLocale)
case SORT_BY_VALUES.AuthorAscending:
return a.author.localeCompare(b.author, this.currentLocale)
case SORT_BY_VALUES.AuthorDescending:
return b.author.localeCompare(a.author, this.currentLocale)
default:
console.error(`Unknown sortOrder: ${this.sortOrder}`)
return 0
}
})
return getSortedPlaylistItems(this.playlistItems, this.sortOrder, this.currentLocale)
},
visiblePlaylistItems: function () {
if (!this.isUserPlaylistRequested) {
Expand Down