« get me outta code hell

linkExternal.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/linkExternal.js
blob: 73c656e3d480a2265365595a292ce13ffbd9eefa (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
// TODO: Define these as extra dependencies and pass them somewhere
const BANDCAMP_DOMAINS = ['bc.s3m.us', 'music.solatrux.com'];
const MASTODON_DOMAINS = ['types.pl'];

export default {
  extraDependencies: ['html', 'language'],

  data(url) {
    return {url};
  },

  slots: {
    mode: {
      validate: v => v.is('generic', 'album', 'flash'),
      default: 'generic',
    },
  },

  generate(data, slots, {html, language}) {
    let isLocal;
    let domain;
    let pathname;
    try {
      const url = new URL(data.url);
      domain = url.hostname;
      pathname = url.pathname;
    } catch (error) {
      // No support for relative local URLs yet, sorry! (I.e, local URLs must
      // be absolute relative to the domain name in order to work.)
      isLocal = true;
    }

    const link = html.tag('a',
      {
        href: data.url,
        class: 'nowrap',
      },

      // truly unhinged indentation here
      isLocal
        ? language.$('misc.external.local')

    : domain.includes('bandcamp.com')
        ? language.$('misc.external.bandcamp')

    : BANDCAMP_DOMAINS.includes(domain)
        ? language.$('misc.external.bandcamp.domain', {domain})

    : MASTODON_DOMAINS.includes(domain)
        ? language.$('misc.external.mastodon.domain', {domain})

    : domain.includes('youtu')
        ? slots.mode === 'album'
          ? data.url.includes('list=')
            ? language.$('misc.external.youtube.playlist')
            : language.$('misc.external.youtube.fullAlbum')
          : language.$('misc.external.youtube')

    : domain.includes('soundcloud')
        ? language.$('misc.external.soundcloud')

    : domain.includes('tumblr.com')
        ? language.$('misc.external.tumblr')

    : domain.includes('twitter.com')
        ? language.$('misc.external.twitter')

    : domain.includes('deviantart.com')
        ? language.$('misc.external.deviantart')

    : domain.includes('wikipedia.org')
        ? language.$('misc.external.wikipedia')

    : domain.includes('poetryfoundation.org')
        ? language.$('misc.external.poetryFoundation')

    : domain.includes('instagram.com')
        ? language.$('misc.external.instagram')

    : domain.includes('patreon.com')
        ? language.$('misc.external.patreon')

    : domain.includes('spotify.com')
        ? language.$('misc.external.spotify')

    : domain.includes('newgrounds.com')
        ? language.$('misc.external.newgrounds')

        : domain);

    switch (slots.mode) {
      case 'flash': {
        const wrap = content =>
          html.tag('span', {class: 'nowrap'}, content);

        if (domain.includes('homestuck.com')) {
          const match = pathname.match(/\/story\/(.*)\/?/);
          if (match) {
            if (isNaN(Number(match[1]))) {
              return wrap(language.$('misc.external.flash.homestuck.secret', {link}));
            } else {
              return wrap(language.$('misc.external.flash.homestuck.page', {
                link,
                page: match[1],
              }));
            }
          }
        } else if (domain.includes('bgreco.net')) {
          return wrap(language.$('misc.external.flash.bgreco', {link}));
        } else if (domain.includes('youtu')) {
          return wrap(language.$('misc.external.flash.youtube', {link}));
        }

        return link;
      }

      default:
        return link;
    }
  }
};