-
Notifications
You must be signed in to change notification settings - Fork 17
/
index.js
74 lines (58 loc) · 1.99 KB
/
index.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
void (function (root, factory) {
if (typeof define === 'function' && define.amd) define(factory)
else if (typeof exports === 'object') module.exports = factory()
else factory()
}(this, function () {
var DETAILS = 'details'
var SUMMARY = 'summary'
var supported = checkSupport()
if (supported) return
// Add a classname
document.documentElement.className += ' no-details'
window.addEventListener('click', clickHandler)
injectStyle('details-polyfill-style',
'html.no-details ' + DETAILS + ' { display: block; }\n' +
'html.no-details ' + DETAILS + ':not([open]) > :not(' + SUMMARY + ') { display: none; }\n' +
'html.no-details ' + DETAILS + ' > ' + SUMMARY + ':before { content: "\u25b6"; display: inline-block; font-size: .8em; width: 1.5em; }\n' +
'html.no-details ' + DETAILS + '[open] > ' + SUMMARY + ':before { content: "\u25bc"; }')
/*
* Click handler for `<summary>` tags
*/
function clickHandler (e) {
if (e.target.nodeName.toLowerCase() === 'summary') {
var details = e.target.parentNode
if (!details) return
if (details.getAttribute('open')) {
details.open = false
details.removeAttribute('open')
} else {
details.open = true
details.setAttribute('open', 'open')
}
}
}
/*
* Checks for support for `<details>`
*/
function checkSupport () {
var el = document.createElement(DETAILS)
if (!('open' in el)) return false
el.innerHTML = '<' + SUMMARY + '>a</' + SUMMARY + '>b'
document.body.appendChild(el)
var diff = el.offsetHeight
el.open = true
var result = (diff != el.offsetHeight)
document.body.removeChild(el)
return result
}
/*
* Injects styles (idempotent)
*/
function injectStyle (id, style) {
if (document.getElementById(id)) return
var el = document.createElement('style')
el.id = id
el.innerHTML = style
document.getElementsByTagName('head')[0].appendChild(el)
}
})); // eslint-disable-line semi