forked from callstack/react-native-paper
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcomponent-docs.config.js
135 lines (121 loc) · 3.51 KB
/
component-docs.config.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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
/* @flow */
import path from 'path';
import fs from 'fs';
const root = path.join(__dirname, '..');
const dist = path.join(__dirname, 'dist');
const assets = [
path.join(__dirname, 'assets', 'gallery'),
path.join(__dirname, 'assets', 'showcase'),
path.join(__dirname, 'assets', 'screenshots'),
path.join(__dirname, 'assets', 'images'),
];
const styles = [path.join(__dirname, 'assets', 'styles.css')];
const scripts = [
path.join(__dirname, 'assets', 'snack.js'),
path.join(__dirname, 'assets', 'version.js'),
];
const github = 'https://github.com/callstack/react-native-paper/edit/master/';
if (!fs.existsSync(dist)) {
fs.mkdirSync(dist);
}
require.extensions['.ts'] = require.extensions['.js'];
require.extensions['.tsx'] = require.extensions['.js'];
function getType(file: string) {
if (/\.(js|tsx?)$/.test(file)) {
return 'custom';
} else if (file.endsWith('.mdx')) {
return 'mdx';
}
return 'md';
}
function getPages() {
const components = fs
.readFileSync(path.join(__dirname, '../src/index.tsx'))
.toString()
.split('\n')
.map(line =>
line
.split(' ')
.pop()
.replace(/('|;)/g, '')
)
.filter(line => line.startsWith('./components/'))
.map(line => {
const file = require.resolve(path.join(__dirname, '../src', line));
if (/\/index\.(js|tsx?)$/.test(file)) {
const matches = fs
.readFileSync(file)
.toString()
.match(/export \{ default \} from .+/);
if (matches && matches.length) {
const name = matches[0]
.split(' ')
.pop()
.replace(/('|;)/g, '');
return require.resolve(path.join(__dirname, '../src', line, name));
}
}
return file;
})
.reduce((acc, file) => {
const content = fs.readFileSync(file).toString();
const groupMatch = /\/\/ @component-group (\w+)/gm.exec(content);
const group = groupMatch ? groupMatch[1] : undefined;
if (/import \* as React/.test(content)) {
acc.push({ file, group });
}
const match = content.match(/\/\/ @component (.\/\w+\.(js|tsx?))/gm);
if (match && match.length) {
const componentFiles = match.map(line => {
const fileName = line.split(' ')[2];
return {
group,
file: require.resolve(
path.join(
file
.split('/')
.slice(0, -1)
.join('/'),
fileName
)
),
};
});
acc.push(...componentFiles);
}
return acc;
}, [])
.filter(
(info, index, self) =>
index === self.findIndex(other => info.file === other.file)
)
.sort((a, b) => {
const nameA = a.file.split('/').pop();
const nameB = b.file.split('/').pop();
return nameA.localeCompare(nameB);
})
.sort((a, b) => {
const nameA = (a.group || a.file).split('/').pop();
const nameB = (b.group || b.file).split('/').pop();
return nameA.localeCompare(nameB);
})
.map(info => ({ ...info, type: 'component' }));
const docs = fs
.readdirSync(path.join(__dirname, 'pages'))
.filter(file => file.includes('.'))
.map(file => ({
file: path.join(__dirname, 'pages', file),
type: getType(file),
}));
return [...docs, { type: 'separator' }, ...components];
}
module.exports = {
root,
logo: 'images/sidebar-logo.svg',
assets,
styles,
scripts,
pages: getPages,
output: dist,
github,
};