« 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: 3dbe38670afecbddcbd83443e5034766b57ca426 (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
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. */
          }),
      ],
    });
  }
};