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
115
116
117
118
119
120
121
|
import {stitchArrays} from '#sugar';
export default {
contentDependencies: [
'generateAlbumSidebarGroupBox',
'generateAlbumSidebarSeriesBox',
'generateAlbumSidebarTrackListBox',
'generatePageSidebar',
'generatePageSidebarConjoinedBox',
],
extraDependencies: ['html', 'wikiData'],
sprawl: ({groupData}) => ({
// TODO: Series aren't their own things, so we access them weirdly.
seriesData:
groupData.flatMap(group => group.serieses),
}),
query(sprawl, album) {
const query = {};
query.groups =
album.groups;
query.groupSerieses =
query.groups
.map(group =>
group.serieses
.filter(series => series.albums.includes(album)));
query.disconnectedSerieses =
sprawl.seriesData
.filter(series =>
series.albums.includes(album) &&
!query.groups.includes(series.group));
return query;
},
relations: (relation, query, _sprawl, 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))),
disconnectedSeriesBoxes:
query.disconnectedSerieses
.map(series =>
relation('generateAlbumSidebarSeriesBox', album, series)),
}),
data: (_query, _sprawl, _album, track) => ({
isAlbumPage: !track,
}),
generate(data, relations, {html}) {
for (const box of [
...relations.groupBoxes,
...relations.seriesBoxes.flat(),
...relations.disconnectedSeriesBoxes,
]) {
box.setSlot('mode',
data.isAlbumPage ? 'album' : 'track');
}
return relations.sidebar.slots({
boxes: [
data.isAlbumPage && [
relations.disconnectedSeriesBoxes,
stitchArrays({
groupBox: relations.groupBoxes,
seriesBoxes: relations.seriesBoxes,
}).map(({groupBox, seriesBoxes}) => [
groupBox,
seriesBoxes.map(seriesBox => [
html.tag('div',
{class: 'sidebar-box-joiner'},
{class: 'collapsible'}),
seriesBox,
]),
]),
],
relations.trackListBox,
!data.isAlbumPage &&
relations.conjoinedBox.slots({
attributes: {class: 'conjoined-group-sidebar-box'},
boxes:
([relations.disconnectedSeriesBoxes,
stitchArrays({
groupBox: relations.groupBoxes,
seriesBoxes: relations.seriesBoxes,
}).flatMap(({groupBox, seriesBoxes}) => [
groupBox,
...seriesBoxes,
]),
]).flat()
.map(box => box.content), /* TODO: Kludge. */
}),
],
});
},
};
|