forked from compat-table/compat-table
-
Notifications
You must be signed in to change notification settings - Fork 33
/
index.pug
104 lines (99 loc) · 4.94 KB
/
index.pug
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
doctype html
html
head
title
block title
| Node.js ES2015/ES6, ES2016 and ES2017 support
meta(http-equiv="Content-Type",content="text/html; charset=utf-8")
link(href='https://fonts.googleapis.com/css?family=Raleway:400,700',rel='stylesheet',type='text/css')
link(href='favico.ico',rel='shortcut icon')
script(async,src="https://www.googletagmanager.com/gtag/js?id=G-07N0XX7S5Z")
script.
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-07N0XX7S5Z');
link(rel="stylesheet", href="style.css")
body
if (flaggable)
input#flagged(type='checkbox')
label(for='flagged') requires
a(href='https://nodejs.org/en/docs/es6/', target="_blank") harmony
| flag ⚐
input#showInfoCode(type='checkbox')
label(for='showInfoCode') show code examples
#credits
| Created by
a(href='https://github.com/williamkapke', target="_blank") William Kapke
header.global
a#node-compat-logo(href='./')
img(src='logo.png')
#subheading
a(href='https://github.com/kangax/compat-table', target="_blank") kangax's compat-table
| applied only to Node.js
#more
a(href='https://github.com/williamkapke/node-compat-table', target="_blank")
img(alt='github' src='')
| Learn more
mixin header(esVersion)
header
h1: a(href="#"+esVersion) Node.js #{esVersion} Support
table.headings
tr
each details, nodeVersion in headers
th.version(class='v' + details.version.split('.')[0])=details.version
.details
small (these versions have identical results)
each detail in details.includes
table: tr
td=detail.version
td=detail.engine
if(details.super)
sup=details.super
if (flaggable)
sub.flagged=percent(nodeVersion, esVersion) + '% complete'
sub.unflagged=percent(nodeVersion, esVersion, true) + '% complete'
mixin article(esVersion)
article(id=esVersion)
+header(esVersion)
each obj1, category in testers[esVersion]
- category2 = esVersion+'-'+category.replace(/\W/g, '-')
table.results
caption
h2.category
.hash(id=category2)
a(href='#'+category2)=category
each obj2, subcategory in obj1
- subcategory2 = [category2,subcategory.replace(/\W/g, '-')].join('-')
tr
td.feature.sub(colspan=Object.keys(headers).length+1)
h3
.hash(id=subcategory2)
a(href='#'+subcategory2)=subcategory
each obj3, subsubcategory in obj2
- subsubcategory2 = [subcategory2,subsubcategory.replace(/\W/g, '-')].join('-')
tr
td.feature.subsub
.hash(id=subsubcategory2)
a.anchor(href='#'+subsubcategory2) §
a(href=obj3.spec)=subsubcategory
if obj3.code
.info
| ?
.fn
| function(){
.code=obj3.code
| }
each nodeVersion in Object.keys(headers)
- classes = requiresFlag(nodeVersion, esVersion, obj3.path)? 'flag' : ''
td.result(class=classes) !{results(nodeVersion, esVersion, obj3.path)}
if obj3.code
tr.codeExample
td
td(colspan=Object.keys(headers).length)
.fn
| function(){
.code=obj3.code
| }
each version in Object.keys(testers)
+article(version)