Skip to content

Commit

Permalink
add UI
Browse files Browse the repository at this point in the history
  • Loading branch information
gooooooooooooogle committed Nov 9, 2021
1 parent e737c6d commit 9a6a83c
Show file tree
Hide file tree
Showing 28 changed files with 1,470 additions and 68 deletions.
30 changes: 30 additions & 0 deletions .babelrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
{
"comments": false,
"env": {
"main": {
"presets": [
["env", {
"targets": { "node": 7 }
}],
"stage-0"
]
},
"renderer": {
"presets": [
["env", {
"modules": false
}],
"stage-0"
]
},
"web": {
"presets": [
["env", {
"modules": false
}],
"stage-0"
]
}
},
"plugins": ["transform-runtime"]
}
150 changes: 150 additions & 0 deletions .electron-vue/build.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,150 @@
'use strict'

process.env.NODE_ENV = 'production'

const { say } = require('cfonts')
const chalk = require('chalk')
const del = require('del')
const { spawn } = require('child_process')
const webpack = require('webpack')
const Listr = require('listr')
const Multispinner = require('multispinner')


const mainConfig = require('./webpack.main.config')
const rendererConfig = require('./webpack.renderer.config')
const webConfig = require('./webpack.web.config')

const doneLog = chalk.bgGreen.white(' DONE ') + ' '
const errorLog = chalk.bgRed.white(' ERROR ') + ' '
const okayLog = chalk.bgBlue.white(' OKAY ') + ' '
const isCI = process.env.CI || false

if (process.env.BUILD_TARGET === 'clean') clean()
else if (process.env.BUILD_TARGET === 'web') web()
else build()

function clean () {
del.sync(['build/*', '!build/icons', '!build/icons/icon.*'])
console.log(`\n${doneLog}\n`)
process.exit()
}

async function build () {
greeting()

del.sync(['dist/electron/*', '!.gitkeep'])

const process_tasks = ['main', 'renderer']
const m = new Multispinner(process_tasks , {
preText: 'building',
postText: 'process'
})

let results = ''

const tasks = new Listr(
[
{
title: 'building master process',
task: async () => {
await pack(mainConfig)
.then(result => {
results += result + '\n\n'
})
.catch(err => {
console.log(`\n ${errorLog}failed to build main process`)
console.error(`\n${err}\n`)
})
}
},
{
title: 'building renderer process',
task: async () => {
await pack(rendererConfig)
.then(result => {
results += result + '\n\n'
})
.catch(err => {
console.log(`\n ${errorLog}failed to build renderer process`)
console.error(`\n${err}\n`)
})
}
}
],
{ concurrent: 2 }
)

await tasks
.run()
.then(() => {
process.stdout.write('\x1B[2J\x1B[0f')
console.log(`\n\n${results}`)
console.log(`${okayLog}take it away ${chalk.yellow('`electron-builder`')}\n`)
process.exit()
})
.catch(err => {
process.exit(1)
})
}

function pack (config) {
return new Promise((resolve, reject) => {
config.mode = 'production'
webpack(config, (err, stats) => {
if (err) reject(err.stack || err)
else if (stats.hasErrors()) {
let err = ''

stats.toString({
chunks: false,
colors: true
})
.split(/\r?\n/)
.forEach(line => {
err += ` ${line}\n`
})

reject(err)
} else {
resolve(stats.toString({
chunks: false,
colors: true
}))
}
})
})
}

function web () {
del.sync(['dist/web/*', '!.gitkeep'])
webConfig.mode = 'production'
webpack(webConfig, (err, stats) => {
if (err || stats.hasErrors()) console.log(err)

console.log(stats.toString({
chunks: false,
colors: true
}))

process.exit()
})
}

function greeting () {
const cols = process.stdout.columns
let text = ''

if (cols > 85) text = 'lets-build'
else if (cols > 60) text = 'lets-|build'
else text = false

if (text && !isCI) {
say(text, {
colors: ['yellow'],
font: 'simple3d',
space: false
})
} else console.log(chalk.yellow.bold('\n lets-build'))
console.log()
}
40 changes: 40 additions & 0 deletions .electron-vue/dev-client.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
// const hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true')

// hotClient.subscribe(event => {
// /**
// * Reload browser when HTMLWebpackPlugin emits a new index.html
// *
// * Currently disabled until jantimon/html-webpack-plugin#680 is resolved.
// * https://github.com/SimulatedGREG/electron-vue/issues/437
// * https://github.com/jantimon/html-webpack-plugin/issues/680
// */
// // if (event.action === 'reload') {
// // window.location.reload()
// // }

// /**
// * Notify `mainWindow` when `main` process is compiling,
// * giving notice for an expected reload of the `electron` process
// */
// if (event.action === 'compiling') {
// document.body.innerHTML += `
// <style>
// #dev-client {
// background: #4fc08d;
// border-radius: 4px;
// bottom: 20px;
// box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
// color: #fff;
// font-family: 'Source Sans Pro', sans-serif;
// left: 20px;
// padding: 8px 12px;
// position: absolute;
// }
// </style>

// <div id="dev-client">
// Compiling Main Process...
// </div>
// `
// }
// })
Loading

0 comments on commit 9a6a83c

Please sign in to comment.