-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
prism-unescaped-markup.js
62 lines (49 loc) · 1.83 KB
/
prism-unescaped-markup.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
(function () {
if (typeof self === 'undefined' || !self.Prism || !self.document) {
return;
}
// https://developer.mozilla.org/en-US/docs/Web/API/Element/matches#Polyfill
if (!Element.prototype.matches) {
Element.prototype.matches = Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;
}
Prism.plugins.UnescapedMarkup = true;
Prism.hooks.add('before-highlightall', function (env) {
env.selector += ', [class*="lang-"] script[type="text/plain"]'
+ ', [class*="language-"] script[type="text/plain"]'
+ ', script[type="text/plain"][class*="lang-"]'
+ ', script[type="text/plain"][class*="language-"]';
});
Prism.hooks.add('before-sanity-check', function (env) {
/** @type {HTMLElement} */
var element = env.element;
if (element.matches('script[type="text/plain"]')) {
// found a <script type="text/plain" ...> element
// we convert this element to a regular <pre><code> code block
var code = document.createElement('code');
var pre = document.createElement('pre');
// copy class name
pre.className = code.className = element.className;
// copy all "data-" attributes
var dataset = element.dataset;
Object.keys(dataset || {}).forEach(function (key) {
if (Object.prototype.hasOwnProperty.call(dataset, key)) {
pre.dataset[key] = dataset[key];
}
});
code.textContent = env.code = env.code.replace(/<\/script(?:>|>)/gi, '</scri' + 'pt>');
// change DOM
pre.appendChild(code);
element.parentNode.replaceChild(pre, element);
env.element = code;
return;
}
if (!env.code) {
// no code
var childNodes = element.childNodes;
if (childNodes.length === 1 && childNodes[0].nodeName == '#comment') {
// the only child is a comment -> use the comment's text
element.textContent = env.code = childNodes[0].textContent;
}
}
});
}());