/
create.js
93 lines (68 loc) · 1.63 KB
/
create.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
const fs = require('fs');
if (process.argv.length <= 2) {
process.exit(-1);
}
const type = process.argv[2];
const path = process.argv[3];
const requestedFiles = process.argv[4];
const filesToCreate = requestedFiles.split(',');
filesToCreate.forEach((file) => {
const fileDir = path === '/' ? `${file}.js` : `${path}/${file}.js`;
const className = file[0].toUpperCase() + file.slice(1);
let content = '';
if (type === 'class') {
content = `import React, { Component } from 'react';
import { StyleSheet, View, Text } from 'react-native';
import PropTypes from 'prop-types';
const styles = StyleSheet.create({
});
class ${className} extends Component {
constructor(props){
super(props);
this.state = {
};
}
render() {
return(
<Text>CommentFooter</Text>
);
}
}
${className}.propTypes = {
style: View.propTypes.style,
};
${className}.defaultProps = {
style: {},
};
export default ${className};
`;
}
if (type === 'dumb') {
content = `import React, { Component } from 'react';
import { StyleSheet, View, Text } from 'react-native';
import PropTypes from 'prop-types';
const styles = StyleSheet.create({
});
const ${className} = ({ style }) => (
<View>CommentFooter</View>
)
${className}.propTypes = {
style: View.propTypes.style,
};
${className}.defaultProps = {
style: {},
};
export default ${className};
`;
}
/* eslint-disable no-console */
try {
if (!fs.existsSync(fileDir)) {
fs.writeFileSync(fileDir, content, 'utf8');
} else {
console.log('\x1b[31m', `File ${fileDir} already exists`);
}
} catch (err) {
console.log('\x1b[31m', err);
}
});