« get me outta code hell

generateAlbumSidebar.js « dependencies « content « src - hsmusic-wiki - HSMusic - static wiki software cataloguing collaborative creation
about summary refs log tree commit diff
path: root/src/content/dependencies/generateAlbumSidebar.js
blob: bd53ef710a63c61136bae594aefce829fa372f24 (plain)
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. */
          }),
      ],
    });
  },
};