/
richtext.js
94 lines (79 loc) · 3.81 KB
/
richtext.js
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
const PrismicRichText = require('@prismicio/richtext');
const { Link: LinkHelper } = require('@prismicio/helpers');
const escapeHtml = require('escape-html');
const { Elements } = PrismicRichText;
function serialize(linkResolver, type, element, content, children) {
switch(type) {
case Elements.heading1: return serializeStandardTag('h1', element, children);
case Elements.heading2: return serializeStandardTag('h2', element, children);
case Elements.heading3: return serializeStandardTag('h3', element, children);
case Elements.heading4: return serializeStandardTag('h4', element, children);
case Elements.heading5: return serializeStandardTag('h5', element, children);
case Elements.heading6: return serializeStandardTag('h6', element, children);
case Elements.paragraph: return serializeStandardTag('p', element, children);
case Elements.preformatted: return serializePreFormatted(element);
case Elements.strong: return serializeStandardTag('strong', element, children);
case Elements.em: return serializeStandardTag('em', element, children);
case Elements.listItem: return serializeStandardTag('li', element, children);
case Elements.oListItem: return serializeStandardTag('li', element, children);
case Elements.list: return serializeStandardTag('ul', element, children);
case Elements.oList: return serializeStandardTag('ol', element, children);
case Elements.image: return serializeImage(linkResolver, element);
case Elements.embed: return serializeEmbed(element);
case Elements.hyperlink: return serializeHyperlink(linkResolver, element, children);
case Elements.label: return serializeLabel(element, children);
case Elements.span: return serializeSpan(content);
default: return '';
}
}
function label(element) {
return element.label ? ` class="${element.label}"` : '';
}
function serializeStandardTag(tag, element, children) {
return `<${tag}${label(element)}>${children.join('')}</${tag}>`;
}
function serializePreFormatted(element) {
return `<pre${label(element)}>${escapeHtml(element.text)}</pre>`;
}
function serializeImage(linkResolver, element) {
const linkUrl = element.linkTo ? LinkHelper.url(element.linkTo, linkResolver) : null;
const linkTarget = element.linkTo && element.linkTo.target ? `target="${element.linkTo.target}" rel="noopener"` : '';
const wrapperClassList = [element.label || '', 'block-img'];
const img = `<img src="${element.url}" alt="${element.alt ? escapeHtml(element.alt) : ''}" copyright="${element.copyright ? escapeHtml(element.copyright) : ''}" />`;
return (`
<p class="${wrapperClassList.join(' ')}">
${linkUrl ? `<a ${linkTarget} href="${linkUrl}">${img}</a>` : img}
</p>
`);
}
function serializeEmbed(element) {
return (`
<div data-oembed="${element.oembed.embed_url}"
data-oembed-type="${element.oembed.type}"
data-oembed-provider="${element.oembed.provider_name}"
${label(element)}>
${element.oembed.html}
</div>
`);
}
function serializeHyperlink(linkResolver, element, children) {
const target = element.data.target ? `target="${element.data.target}" rel="noopener"` : '';
const url = escapeHtml(LinkHelper.url(element.data, linkResolver));
return `<a ${target} href="${url}">${children.join('')}</a>`;
}
function serializeLabel(element, children) {
return `<span ${label(element.data)}>${children.join('')}</span>`;
}
function serializeSpan(content) {
return content ? escapeHtml(content).replace(/\n/g, '<br />') : '';
}
module.exports = {
asText(structuredText, joinString) {
return PrismicRichText.asText(structuredText, joinString);
},
asHtml(richText, linkResolver, htmlSerializer) {
const serialized = PrismicRichText.serialize(richText, serialize.bind(null, linkResolver), htmlSerializer);
return serialized.join('');
},
Elements : Elements
};