forked from postlight/lorem-ipsum-generator-generator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcli.js
181 lines (158 loc) · 4.62 KB
/
cli.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
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
#! /usr/bin/env node
var fs = require("fs")
var spawn = require("cross-spawn")
var path = require("path")
var Mercury = require("@postlight/mercury-parser")
var markov = require("markov")
var slugify = require("slugify")
var commander = require("commander")
var inquirer = require("inquirer")
var program = new commander.Command('lorem-ipsum-generator-generator')
.version("1.0.0")
.usage('<urls ...> [options]')
.option('-p, --project-name [name]')
.option('-l, --logo [logo]')
.option('-b, --background [background]')
.option('-a, --accent [accent]')
.parse(process.argv)
var options = {
name: program.projectName,
logo: program.logo,
background: program.background,
accent: program.accent,
urls: program.args
}
run()
async function run() {
if (!options.name) {
await ask()
}
if (options.urls.length === 0) {
await askUrls()
}
generate()
}
async function ask() {
var answers = await inquirer.prompt([
{
type: 'input',
name: 'name',
message: 'Name of your generator:',
default: options.name,
validate: Boolean
},
{
type: 'input',
name: 'logo',
message: '(Optional) URL of a logo image:',
default: options.logo
},
{
type: 'input',
name: 'background',
message: '(Optional) URL of a background image:',
default: options.background
},
{
type: 'input',
name: 'accent',
message: '(Optional) Accent color (hex, rgb, named color, whatever):',
default: options.accent
}
])
options.name = answers.name
options.logo = answers.logo
options.background = answers.background
options.accent = answers.accent
}
async function askUrls() {
var answers = await inquirer.prompt([
{
type: 'input',
name: 'url',
message: 'URL of a source for your generator:'
},
{
type: 'confirm',
name: 'addUrl',
message: 'Add another source?',
default: true
}
])
options.urls.push(answers.url)
if (answers.addUrl) {
await askUrls()
}
}
async function generate() {
var name = slugify(options.name, {lower: true})
var root = path.resolve(name)
var corpus = await fetchText(options.urls)
if (!corpus) {
console.log('Mercury couldn’t find any usable text at your sources.')
process.exit()
}
if (fs.existsSync(root)) {
console.log(`A folder with the name ${name} already exists. We don't want to overwrite that!`)
process.exit()
}
fs.mkdirSync(root);
fs.mkdirSync(path.join(root, 'functions'))
fs.mkdirSync(path.join(root, 'functions/generate'))
var files = [
'postlight-labs.gif',
'functions/generate/generate.js',
'functions/generate/package.json'
]
files.forEach(f => fs.copyFileSync(path.join(__dirname, f), path.join(root, f)))
writeDb(corpus)
var packageJson = {
name,
version: '1.0.0',
private: true,
description: 'A lorem ipsum generator based on text found by Mercury Parser',
scripts: {
deploy: './node_modules/.bin/netlify deploy --prod --open'
},
dependencies: {
"netlify-cli": "2.8.3"
}
}
fs.writeFileSync(path.join(root, 'package.json'), JSON.stringify(packageJson, null, 2))
var index = fs.readFileSync(path.join(__dirname, 'index.html'), 'utf8')
var updatedIndex = index.replace(/My Ipsum/g, options.name)
if (options.logo) {
updatedIndex = updatedIndex.replace(/<!-- LOGO -->/g, `<img id="logo" src="${options.logo}" alt="" />`)
}
if (options.background) {
updatedIndex = updatedIndex.replace(/dimgray/g, `url('${options.background}')`)
}
if (options.accent) {
updatedIndex = updatedIndex.replace(/#111111/g, options.accent)
}
fs.writeFileSync(path.join(root, 'index.html'), updatedIndex)
process.chdir(root)
var npmInstall = spawn.sync('npm', ['install'], { stdio: 'inherit' })
process.chdir(path.join(root, 'functions/generate'))
var npmInstallFunc = spawn.sync('npm', ['install'], { stdio: 'inherit' })
process.chdir(root)
var netlifyDeploy = spawn.sync(
'./node_modules/.bin/netlify',
['deploy', '--prod', '--open', '--functions', 'functions'],
{ stdio: 'inherit' }
)
return true
function writeDb(corpus) {
var m = markov(2)
m.seed(corpus, () => {
fs.writeFileSync(path.join(root, 'functions/generate/db.json'), JSON.stringify(m.getDb()))
})
}
}
async function fetchText(urls = []) {
var contents = urls.map(async u => {
var res = await Mercury.parse(u, {contentType: 'text'})
return res.content.trim()
})
return Promise.all(contents).then(c => c.join(''))
}