-
Notifications
You must be signed in to change notification settings - Fork 15
/
playlistSelectors.js
114 lines (96 loc) · 2.77 KB
/
playlistSelectors.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
import { createSelector } from 'reselect';
import naturalCmp from 'natural-compare';
const byName = (a, b) => naturalCmp(a.name.toLowerCase(), b.name.toLowerCase());
const baseSelector = (state) => state.playlists;
export const playlistsSelector = createSelector(
baseSelector,
(playlists) => Object.values(playlists.playlists).sort(byName),
);
export const playlistItemsSelector = createSelector(
baseSelector,
(playlists) => playlists.playlistItems,
);
export const activePlaylistIDSelector = createSelector(
baseSelector,
(playlists) => playlists.activePlaylistID,
);
const activeMediaSelector = createSelector(
playlistItemsSelector,
activePlaylistIDSelector,
(playlistItems, activePlaylist) => playlistItems[activePlaylist] || [],
);
function mergePlaylistItems(playlist, playlistItems) {
if (playlist) {
return {
...playlist,
media: playlistItems,
};
}
return null;
}
export const activePlaylistSelector = createSelector(
baseSelector,
activePlaylistIDSelector,
activeMediaSelector,
(playlists, activeID, activeMedia) => (
mergePlaylistItems(playlists.playlists[activeID], activeMedia)
),
);
export const selectedPlaylistIDSelector = createSelector(
baseSelector,
(playlists) => playlists.selectedPlaylistID,
);
const selectedMediaSelector = createSelector(
playlistItemsSelector,
selectedPlaylistIDSelector,
(playlistItems, selectedPlaylist) => playlistItems[selectedPlaylist] || [],
);
const filterSelector = createSelector(
baseSelector,
(base) => base.currentFilter,
);
const currentFilterSelector = createSelector(
filterSelector,
selectedPlaylistIDSelector,
(filter, selectedID) => {
if (filter && filter.playlistID === selectedID) {
return filter;
}
return null;
},
);
export const playlistItemFilterSelector = createSelector(
currentFilterSelector,
(filter) => filter && filter.filter,
);
export const filteredSelectedPlaylistItemsSelector = createSelector(
selectedPlaylistIDSelector,
selectedMediaSelector,
currentFilterSelector,
(selectedID, selectedItems, filter) => {
if (filter) {
return filter.items;
}
return selectedItems;
},
);
export const selectedPlaylistSelector = createSelector(
baseSelector,
selectedPlaylistIDSelector,
selectedMediaSelector,
(playlists, selectedID, selectedMedia) => (
mergePlaylistItems(playlists.playlists[selectedID], selectedMedia)
),
);
export const nextMediaSelector = createSelector(
activeMediaSelector,
(media) => (media ? media[0] : null),
);
export const isSelectedPlaylistLoadingSelector = createSelector(
selectedPlaylistSelector,
(selectedPlaylist) => Boolean(selectedPlaylist.loading),
);
export const isFilteredSelector = createSelector(
playlistItemFilterSelector,
(filter) => Boolean(filter),
);