forked from ivmarcos/react-to-pdf
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstyleguide.config.js
102 lines (94 loc) · 2.93 KB
/
styleguide.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
// /const OpenBrowserPlugin = require('open-browser-webpack-plugin');
const path = require('path');
const fs = require('fs');
const OpenBrowserPlugin = require('open-browser-webpack-plugin');
const srcFolder = path.join(__dirname, 'src');
function isMarkdown(file) {
return /\.md$/.test(file);
}
function hasAnnotation(file) {
const buffer = fs.readFileSync(file);
return /@styleguide/g.test(buffer.toString());
}
const componentsWithMD = [];
const componentsWithAnnotation = [];
function findComponentsWithMD(folder, map) {
const files = fs.readdirSync(folder);
files.forEach(file => {
const filePath = path.join(folder, file);
const stat = fs.statSync(filePath);
if (stat.isFile()) {
if (isMarkdown(filePath)) {
const jsxFile = filePath.replace('.md', '.jsx');
if (fs.existsSync(jsxFile)) {
componentsWithMD.push(jsxFile);
if (hasAnnotation(jsxFile)) {
componentsWithAnnotation.push(jsxFile);
}
}
}
} else {
findComponentsWithMD(filePath, map);
}
});
}
findComponentsWithMD(srcFolder);
console.log('componentsWithAnnotation', componentsWithAnnotation);
module.exports = {
serverHost: 'localhost',
serverPort: 6061,
styleguideDir: 'public',
title: 'Planner SM-UI',
styleguideComponents: {
Wrapper: path.join(__dirname, 'src/Wrapper')
},
components: 'src/**/*.jsx',
//components: componentsWithAnnotation.length ? componentsWithAnnotation : componentsWithMD,
webpackConfig: {
devtool: 'sourcemap',
module: {
rules: [
// Babel loader, will use your project’s .babelrc
{
test: /\.jsx?$/,
exclude: /node_modules/,
loader: 'babel-loader'
},
// Other loaders that are needed for your components
{
test: /\.s?css$/,
loaders: ['style-loader', 'css-loader?importLoaders=1', 'sass-loader?precision=10']
},
{
test: /\.svg$/,
loader: 'url-loader?limit=65000&mimetype=image/svg+xml&name=public/fonts/[name].[ext]'
},
{
test: /\.(png|jpg|gif)$/,
loader: 'url-loader?limit=65000&name=public/static/[name].[ext]'
},
{
test: /\.woff$/,
loader:
'url-loader?limit=65000&mimetype=application/font-woff&name=public/fonts/[name].[ext]'
},
{
test: /\.woff2$/,
loader:
'url-loader?limit=65000&mimetype=application/font-woff2&name=public/fonts/[name].[ext]'
},
{
test: /\.[ot]tf$/,
loader:
'url-loader?limit=65000&mimetype=application/octet-stream&name=public/fonts/[name].[ext]'
},
{
test: /\.eot$/,
loader:
'url-loader?limit=65000&mimetype=application/vnd.ms-fontobject&name=public/fonts/[name].[ext]'
}
]
},
plugins: [new OpenBrowserPlugin({ url: 'http://localhost:6061' })]
}
};