« get me outta code hell

generateTrackNavLinks.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/generateTrackNavLinks.js
blob: 21ba48db411b6b9a0eea510f7a47462679a1450f (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
export default {
  relations: (relation, track) => ({
    albumLink:
      relation('linkAlbum', track.album),

    trackLink:
      relation('linkTrack', track),
  }),

  data: (track) => ({
    albumStyle:
      track.album.style,

    showTrackSection:
      track.album.showTrackSectionInNavBar,

    hasTrackNumbers:
      track.album.hasTrackNumbers,

    trackSectionName:
      track.trackSection.name,

    trackNumber:
      track.trackNumber,

    nameDetail:
      track.nameDetail,
  }),

  slots: {
    currentExtra: {
      validate: v => v.is('referenced-art', 'referencing-art'),
    },
  },

  generate: (data, relations, slots, {html, language}) =>
    language.encapsulate('trackPage.nav', navCapsule => [
      {auto: 'home'},

      {
        html: relations.albumLink.slot('color', false),
        accent:
          (data.albumStyle === 'single'
            ? language.$(navCapsule, 'singleAccent')
            : null),
      },

      data.showTrackSection &&
        {
          html:
            relations.albumLink.clone()
              .slot('content', language.sanitize(data.trackSectionName)),
        },

      {
        html:
          language.encapsulate(navCapsule, 'track', workingCapsule => {
            const workingOptions = {};

            workingOptions.track =
              relations.trackLink
                .slot('attributes', {class: 'current'});

            if (data.hasTrackNumbers) {
              workingCapsule += '.withNumber';
              workingOptions.number = data.trackNumber;
            }

            return language.$(workingCapsule, workingOptions);
          }),

        accent:
          language.formatUnitList([
            language.sanitize(data.nameDetail),

            html.tag('a',
              {[html.onlyIfContent]: true},

              {href: ''},
              {class: 'current'},

              (slots.currentExtra === 'referenced-art'
                ? language.$('referencedArtworksPage.subtitle')
             : slots.currentExtra === 'referencing-art'
                ? language.$('referencingArtworksPage.subtitle')
                : null)),
          ]),
      },
    ]),
};