-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprepare.js
80 lines (75 loc) · 3.44 KB
/
prepare.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
//@ts-check
const playwright = require('playwright');
const path = require('path');
const fs = require('fs');
(async function() {
const [chromium, webkit, firefox] = await Promise.all([
gatherChromiumCSS(),
gatherWebkitCSS(),
gatherFirefoxCSS()
]);
const intersection = [];
for (const key of chromium) {
if (webkit.has(key) && firefox.has(key))
intersection.push(key);
}
intersection.sort();
fs.writeFileSync(path.join(__dirname, 'index.json'), JSON.stringify(intersection), 'utf8');
const readmePath = path.join(__dirname, 'README.md');
const readme = fs.readFileSync(readmePath, 'utf8');
const beginning = readme.substring(0, readme.indexOf('<!-- gen list -->') + '<!-- gen list -->'.length);
const readmeWithList = beginning + '\n' + intersection.map(keyToMarkdown).join('\n');
fs.writeFileSync(readmePath, readmeWithList, 'utf8');
})();
function keyToMarkdown(cssKey) {
// css properties for svg attributes have different MDN links
const svgKeys = new Set([ 'clip-rule', 'color-interpolation', 'color-interpolation-filters', 'cx', 'cy', 'dominant-baseline', 'fill', 'fill-opacity', 'fill-rule', 'flood-color', 'flood-opacity', 'lighting-color', 'marker', 'marker-end', 'marker-mid', 'marker-start', 'r', 'rx', 'ry', 'shape-rendering', 'stop-color', 'stop-opacity', 'stroke', 'stroke-dasharray', 'stroke-dashoffset', 'stroke-linecap', 'stroke-linejoin', 'stroke-miterlimit', 'stroke-opacity', 'stroke-width', 'text-anchor', 'vector-effect', 'x', 'y']);
const isSVG = svgKeys.has(cssKey);
const keyWithoutPrefix = cssKey.startsWith('-webkit-') ? cssKey.substring('-webkit-'.length) : cssKey;
return ` - [${cssKey}](https://developer.mozilla.org/docs/Web/${isSVG ? 'SVG/Attribute' : 'CSS'}/${keyWithoutPrefix})`;
}
async function gatherChromiumCSS() {
const browser = await playwright.chromium.launch();
const [page] = await browser.defaultContext().pages();
const result = await page.evaluate(() => {
const cssKeys = Object.keys(document.body.style).map(key => {
const split = key.split(/(?=[A-Z])/).join('-').toLowerCase();
if (split.startsWith('webkit'))
return '-' + split;
return split;
});
return cssKeys.filter(key => {
return CSS.supports(key, 'initial');
});
});
await browser.close();
return new Set(result);
}
async function gatherFirefoxCSS() {
const browser = await playwright.firefox.launch({headless: true});
const [page] = await browser.defaultContext().pages();
const result = await page.evaluate(() => {
return Object.keys(document.body.style['__proto__']).filter(key => {
return key === key.toLowerCase() && CSS.supports(key, 'initial');
});
});
await browser.close();
return new Set(result);
}
async function gatherWebkitCSS() {
const browser = await playwright.webkit.launch();
const [page] = await browser.defaultContext().pages();
const result = await page.evaluate(() => {
const cssKeys = Object.keys(document.body.style).map(key => {
const split = key.split(/(?=[A-Z])/).join('-').toLowerCase();
if (split.startsWith('webkit'))
return '-' + split;
return split;
});
return cssKeys.filter(key => {
return CSS.supports(key, 'initial');
});
});
await browser.close();
return new Set(result);
}