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
|
import {isExternalLinkContext} from '#external-links';
export default {
extraDependencies: ['html', 'language', 'wikiData'],
sprawl: ({wikiInfo}) => ({wikiInfo}),
data(sprawl, url) {
const data = {url};
const {canonicalBase} = sprawl.wikiInfo;
if (canonicalBase) {
const {hostname: canonicalDomain} = new URL(canonicalBase);
Object.assign(data, {canonicalDomain});
}
return data;
},
slots: {
context: {
// This awkward syntax is because the slot descriptor validator can't
// differentiate between a function that returns a validator (the usual
// syntax) and a function that is itself a validator.
validate: () => isExternalLinkContext,
default: 'generic',
},
},
generate(data, slots, {html, language}) {
return (
html.tag('a',
{href: data.url, class: 'nowrap'},
language.formatExternalLink(data.url, {
style: 'platform',
context: slots.context,
})));
},
/*
: domain.includes('youtu')
? slots.mode === 'album'
? data.url.includes('list=')
? language.$('misc.external.youtube.playlist')
: language.$('misc.external.youtube.fullAlbum')
: language.$('misc.external.youtube')
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;
}
*/
};
|