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
|
import {stitchArrays} from '#sugar';
export default {
contentDependencies: [
'generateAlbumSidebarGroupBox',
'generateAlbumSidebarSeriesBox',
'generateAlbumSidebarTrackListBox',
'generatePageSidebar',
'generatePageSidebarConjoinedBox',
],
extraDependencies: ['html'],
query(album) {
const query = {};
query.groups =
album.groups;
query.groupSerieses =
query.groups
.map(group =>
group.serieses
.filter(series => series.albums.includes(album)));
return query;
},
relations: (relation, query, album, track) => ({
sidebar:
relation('generatePageSidebar'),
conjoinedBox:
relation('generatePageSidebarConjoinedBox'),
trackListBox:
relation('generateAlbumSidebarTrackListBox', album, track),
groupBoxes:
query.groups
.map(group =>
relation('generateAlbumSidebarGroupBox', album, group)),
seriesBoxes:
query.groupSerieses
.map(serieses => serieses
.map(series =>
relation('generateAlbumSidebarSeriesBox', album, series))),
}),
data: (_query, _album, track) => ({
isAlbumPage: !track,
}),
generate(data, relations, {html}) {
for (const box of [
...relations.groupBoxes,
...relations.seriesBoxes.flat(),
]) {
box.setSlot('mode',
data.isAlbumPage ? 'album' : 'track');
}
const groupAndSeriesBoxes =
stitchArrays({
groupBox: relations.groupBoxes,
seriesBoxes: relations.seriesBoxes,
}).map(({groupBox, seriesBoxes}) =>
[groupBox].concat(
seriesBoxes.map(seriesBox => [
html.tag('div',
{class: 'sidebar-box-joiner'},
{class: 'collapsible'}),
seriesBox,
])))
.flat();
return relations.sidebar.slots({
boxes: [
data.isAlbumPage &&
groupAndSeriesBoxes,
relations.trackListBox,
!data.isAlbumPage &&
relations.conjoinedBox.slots({
attributes: {class: 'conjoined-group-sidebar-box'},
boxes:
groupAndSeriesBoxes
.map(box => box.content), /* TODO: Kludge. */
}),
],
});
}
};
|