From 5c251f52e0e4aae2d4775422f2d6e59bbb31436a Mon Sep 17 00:00:00 2001 From: Jeff Date: Tue, 7 Aug 2018 23:03:45 -0700 Subject: [PATCH] Remove build and config folders --- build/build-docs.js | 9 ----- build/build.js | 35 ---------------- build/dev-client.js | 9 ----- build/dev-server.js | 65 ----------------------------- build/utils.js | 83 -------------------------------------- build/webpack.base.conf.js | 71 -------------------------------- build/webpack.dev.conf.js | 39 ------------------ build/webpack.prod.conf.js | 32 --------------- build/webpack.site.conf.js | 83 -------------------------------------- config/dev.env.js | 6 --- config/index.js | 30 -------------- config/prod.env.js | 3 -- config/test.env.js | 6 --- 13 files changed, 471 deletions(-) delete mode 100644 build/build-docs.js delete mode 100644 build/build.js delete mode 100644 build/dev-client.js delete mode 100644 build/dev-server.js delete mode 100644 build/utils.js delete mode 100644 build/webpack.base.conf.js delete mode 100644 build/webpack.dev.conf.js delete mode 100644 build/webpack.prod.conf.js delete mode 100644 build/webpack.site.conf.js delete mode 100644 config/dev.env.js delete mode 100644 config/index.js delete mode 100644 config/prod.env.js delete mode 100644 config/test.env.js diff --git a/build/build-docs.js b/build/build-docs.js deleted file mode 100644 index 7c3cc28..0000000 --- a/build/build-docs.js +++ /dev/null @@ -1,9 +0,0 @@ -// https://github.com/shelljs/shelljs -const shell = require('shelljs'); - -shell.exec('gitbook build', (code, stdout, stderr) => { - if( code === 0 ) { - shell.rm('-rf', 'site/docs'); - shell.exec('mv _book site/docs') - } -}); \ No newline at end of file diff --git a/build/build.js b/build/build.js deleted file mode 100644 index 9ca4c5c..0000000 --- a/build/build.js +++ /dev/null @@ -1,35 +0,0 @@ -// https://github.com/shelljs/shelljs -require('shelljs/global'); -env.NODE_ENV = 'production'; - -var path = require('path'); -var config = require('../config'); -var ora = require('ora'); -var webpack = require('webpack'); -var utils = require('./utils'); -var webpackConfig = utils.shouldBuildHomepage() ? require('./webpack.site.conf') : require('./webpack.prod.conf'); - -var text = utils.shouldBuildHomepage() ? 'homepage' : 'vue-select UMD module'; -var spinner = ora(`building ${text}...`); -spinner.start(); - -var assetsPath = path.join(config.build.assetsRoot, config.build.assetsSubDirectory); -if (!utils.shouldBuildHomepage()) { - rm('-rf', assetsPath); - mkdir('-p', assetsPath); -} - -/** - * Build the /dist/ folder - */ -webpack(webpackConfig, function (err, stats) { - spinner.stop(); - if (err) throw err; - process.stdout.write(stats.toString({ - colors: true, - modules: false, - children: false, - chunks: false, - chunkModules: false - }) + '\n') -}); \ No newline at end of file diff --git a/build/dev-client.js b/build/dev-client.js deleted file mode 100644 index 18aa1e2..0000000 --- a/build/dev-client.js +++ /dev/null @@ -1,9 +0,0 @@ -/* eslint-disable */ -require('eventsource-polyfill') -var hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true') - -hotClient.subscribe(function (event) { - if (event.action === 'reload') { - window.location.reload() - } -}) diff --git a/build/dev-server.js b/build/dev-server.js deleted file mode 100644 index b4d8133..0000000 --- a/build/dev-server.js +++ /dev/null @@ -1,65 +0,0 @@ -var path = require('path') -var express = require('express') -var webpack = require('webpack') -var config = require('../config') -var proxyMiddleware = require('http-proxy-middleware') -var webpackConfig = process.env.NODE_ENV === 'testing' - ? require('./webpack.prod.conf') - : require('./webpack.dev.conf') - -// default port where dev server listens for incoming traffic -var port = process.env.PORT || config.dev.port -// Define HTTP proxies to your custom API backend -// https://github.com/chimurai/http-proxy-middleware -var proxyTable = config.dev.proxyTable - -var app = express() -var compiler = webpack(webpackConfig) - -var devMiddleware = require('webpack-dev-middleware')(compiler, { - publicPath: webpackConfig.output.publicPath, - stats: { - colors: true, - chunks: false - } -}) - -var hotMiddleware = require('webpack-hot-middleware')(compiler) -// force page reload when html-webpack-plugin template changes -compiler.plugin('compilation', function (compilation) { - compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) { - hotMiddleware.publish({ action: 'reload' }) - cb() - }) -}) - -// proxy api requests -Object.keys(proxyTable).forEach(function (context) { - var options = proxyTable[context] - if (typeof options === 'string') { - options = { target: options } - } - app.use(proxyMiddleware(context, options)) -}) - -// handle fallback for HTML5 history API -app.use(require('connect-history-api-fallback')()) - -// serve webpack bundle output -app.use(devMiddleware) - -// enable hot-reload and state-preserving -// compilation error display -app.use(hotMiddleware) - -// serve pure static assets -var staticPath = path.posix.join(config.build.assetsPublicPath, config.build.assetsSubDirectory) -app.use(staticPath, express.static('./static')) - -module.exports = app.listen(port, function (err) { - if (err) { - console.log(err) - return - } - console.log('Listening at http://localhost:' + port + '\n') -}) diff --git a/build/utils.js b/build/utils.js deleted file mode 100644 index 7b26e66..0000000 --- a/build/utils.js +++ /dev/null @@ -1,83 +0,0 @@ -var path = require('path') -var config = require('../config') -var ExtractTextPlugin = require('extract-text-webpack-plugin') - -/** - * Get the path to the assetsSubDirectory - * @param _path - * @returns {*|string} - */ -exports.assetsPath = function (_path) { - return path.posix.join(config.build.assetsSubDirectory, _path) -} - -/** - * Generate loader string to be used with extract text plugin - * @param options - * @returns {{css: *, postcss: *, less: *, sass: *, scss: *, stylus: *, styl: *}} - */ -exports.cssLoaders = function (options) { - options = options || {} - - function generateLoaders (loaders) { - var sourceLoader = loaders.map(function (loader) { - var extraParamChar - if (/\?/.test(loader)) { - loader = loader.replace(/\?/, '-loader?') - extraParamChar = '&' - } else { - loader = loader + '-loader' - extraParamChar = '?' - } - return loader + (options.sourceMap ? extraParamChar + 'sourceMap' : '') - }).join('!') - - if (options.extract) { - return ExtractTextPlugin.extract('vue-style-loader', sourceLoader) - } else { - return ['vue-style-loader', sourceLoader].join('!') - } - } - - // http://vuejs.github.io/vue-loader/configurations/extract-css.html - return { - css: generateLoaders(['css']), - postcss: generateLoaders(['css']), - less: generateLoaders(['css', 'less']), - sass: generateLoaders(['css', 'sass?indentedSyntax']), - scss: generateLoaders(['css', 'sass']), - stylus: generateLoaders(['css', 'stylus']), - styl: generateLoaders(['css', 'stylus']) - } -} - -/** - * Generate loaders for standalone style files (outside of .vue) - * @param options - * @returns {Array} - */ -exports.styleLoaders = function (options) { - var output = [] - var loaders = exports.cssLoaders(options) - for (var extension in loaders) { - var loader = loaders[extension] - output.push({ - test: new RegExp('\\.' + extension + '$'), - loader: loader - }) - } - return output -} - -/** - * Are we serving the docs or - * the dev environment? - * @returns {boolean} - */ -exports.shouldServeHomepage = function () { - return process.argv.indexOf('--docs') > 0 -} - -exports.shouldBuildHomepage = function () { - return process.argv.indexOf('--homepage') > 0 -} \ No newline at end of file diff --git a/build/webpack.base.conf.js b/build/webpack.base.conf.js deleted file mode 100644 index 4ef799b..0000000 --- a/build/webpack.base.conf.js +++ /dev/null @@ -1,71 +0,0 @@ -var path = require('path') -var config = require('../config') -var utils = require('./utils') -var projectRoot = path.resolve(__dirname, '../') - -module.exports = { - entry: { - app: utils.shouldServeHomepage() ? './docs/homepage/home.js' : './dev/dev.js', - }, - output: { - path: config.build.assetsRoot, - publicPath: config.build.assetsPublicPath, - filename: '[name].js' - }, - resolve: { - extensions: ['', '.js', '.vue'], - fallback: [path.join(__dirname, '../node_modules')], - alias: { - 'src': path.resolve(__dirname, '../src'), - 'assets': path.resolve(__dirname, '../docs/assets'), - 'mixins': path.resolve(__dirname, '../src/mixins'), - 'components': path.resolve(__dirname, '../src/components'), - 'docs': path.resolve(__dirname, '../docs'), - 'vue$': 'vue/dist/vue.common.js', - } - }, - resolveLoader: { - fallback: [path.join(__dirname, '../node_modules')] - }, - module: { - loaders: [ - { - test: /\.vue$/, - loader: 'vue-loader' - }, - { - test: /\.js$/, - loader: 'babel-loader', - include: projectRoot, - exclude: /node_modules/ - }, - { - test: /\.json$/, - loader: 'json-loader' - }, - { - test: /\.html$/, - loader: 'vue-html-loader' - }, - { - test: /\.(png|jpe?g|gif)(\?.*)?$/, - loader: 'url', - query: { - limit: 10000, - name: utils.assetsPath('img/[name].[hash:7].[ext]') - } - }, - { - test: /\.(woff2?|eot|ttf|otf|svg)(\?.*)?$/, - loader: 'url', - query: { - limit: 10000, - name: utils.assetsPath('fonts/[name].[hash:7].[ext]') - } - } - ] - }, - vue: { - loaders: utils.cssLoaders() - } -} diff --git a/build/webpack.dev.conf.js b/build/webpack.dev.conf.js deleted file mode 100644 index 9d26cc7..0000000 --- a/build/webpack.dev.conf.js +++ /dev/null @@ -1,39 +0,0 @@ -var config = require('../config') -var webpack = require('webpack') -var merge = require('webpack-merge') -var utils = require('./utils') -var baseWebpackConfig = require('./webpack.base.conf') -var HtmlWebpackPlugin = require('html-webpack-plugin') - -// add hot-reload related code to entry chunks -Object.keys(baseWebpackConfig.entry).forEach(function (name) { - baseWebpackConfig.entry[name] = ['./build/dev-client'].concat(baseWebpackConfig.entry[name]) -}) - -module.exports = merge(baseWebpackConfig, { - module: { - loaders: utils.styleLoaders().concat({ test: /\.md$/, loader: "html!markdown" }) - }, - // eval-source-map is faster for development - devtool: '#eval-source-map', - plugins: [ - new webpack.DefinePlugin({ - 'process.env': config.dev.env - }), - // https://github.com/glenjamin/webpack-hot-middleware#installation--usage - new webpack.optimize.OccurenceOrderPlugin(), - new webpack.HotModuleReplacementPlugin(), - new webpack.NoErrorsPlugin(), - // https://github.com/ampedandwired/html-webpack-plugin - new HtmlWebpackPlugin({ - filename: 'index.html', - template: utils.shouldServeHomepage() ? './docs/homepage/home.html' : './dev/dev.html', - inject: true - }) - ], - markdownLoader: { - highlight: function (code) { - return require('highlight.js').highlightAuto(code).value; - } - } -}) diff --git a/build/webpack.prod.conf.js b/build/webpack.prod.conf.js deleted file mode 100644 index 06c9457..0000000 --- a/build/webpack.prod.conf.js +++ /dev/null @@ -1,32 +0,0 @@ -const webpack = require('webpack') -const base = require('./webpack.base.conf') -const config = require('../config') - -base.entry = { - lib: './src/index.js' -} - -base.output = { - path: config.build.assetsRoot, - publicPath: config.build.assetsPublicPath, - filename: 'vue-select.js', - library: 'VueSelect', - libraryTarget: 'umd' -} - -var webpackConfig = Object.assign({}, base) - -webpackConfig.devtool = '#source-map' -webpackConfig.plugins = (webpackConfig.plugins || []).concat([ - new webpack.DefinePlugin({ - 'process.env': { - NODE_ENV: '"production"' - } - }), - new webpack.optimize.UglifyJsPlugin({ - compress: { warnings: false } - }), - new webpack.optimize.OccurenceOrderPlugin(), -]) - -module.exports = webpackConfig diff --git a/build/webpack.site.conf.js b/build/webpack.site.conf.js deleted file mode 100644 index 1d53b2a..0000000 --- a/build/webpack.site.conf.js +++ /dev/null @@ -1,83 +0,0 @@ -var path = require('path') -var config = require('../config') -var utils = require('./utils') -var webpack = require('webpack') -var merge = require('webpack-merge') -var baseWebpackConfig = require('./webpack.base.conf') -var ExtractTextPlugin = require('extract-text-webpack-plugin') -var HtmlWebpackPlugin = require('html-webpack-plugin') -var env = process.env.NODE_ENV === 'testing' - ? require('../config/test.env') - : config.homepage.env - -module.exports = merge(baseWebpackConfig, { - entry: { - app: config.homepage.entry - }, - module: { - loaders: utils.styleLoaders({ sourceMap: config.homepage.productionSourceMap, extract: true }) - }, - devtool: config.homepage.productionSourceMap ? '#source-map' : false, - output: { - publicPath: config.homepage.assetsPublicPath, - path: config.homepage.assetsRoot, - filename: utils.assetsPath('js/[name].[chunkhash].js'), - chunkFilename: utils.assetsPath('js/[id].[chunkhash].js') - }, - vue: { - loaders: utils.cssLoaders({ - sourceMap: config.homepage.productionSourceMap, - extract: true - }) - }, - plugins: [ - // http://vuejs.github.io/vue-loader/workflow/production.html - new webpack.DefinePlugin({ - 'process.env': env - }), - new webpack.optimize.UglifyJsPlugin({ - compress: { - warnings: false - } - }), - new webpack.optimize.OccurenceOrderPlugin(), - // extract css into its own file - new ExtractTextPlugin(utils.assetsPath('css/[name].[contenthash].css')), - // generate dist index.html with correct asset hash for caching. - // you can customize output by editing /index.html - // see https://github.com/ampedandwired/html-webpack-plugin - new HtmlWebpackPlugin({ - filename: 'index.html', - template: './docs/homepage/home.html', - inject: true, - minify: { - removeComments: true, - collapseWhitespace: true, - removeAttributeQuotes: true - // more options: - // https://github.com/kangax/html-minifier#options-quick-reference - }, - // necessary to consistently work with multiple chunks via CommonsChunkPlugin - chunksSortMode: 'dependency' - }), - // split vendor js into its own file - new webpack.optimize.CommonsChunkPlugin({ - name: 'vendor', - minChunks: function (module, count) { - // any required modules inside node_modules are extracted to vendor - return ( - module.resource && - module.resource.indexOf( - path.join(__dirname, '../node_modules') - ) === 0 - ) - } - }), - // extract webpack runtime and module manifest to its own file in order to - // prevent vendor hash from being updated whenever app bundle is updated - new webpack.optimize.CommonsChunkPlugin({ - name: 'manifest', - chunks: ['vendor'] - }) - ] -}) diff --git a/config/dev.env.js b/config/dev.env.js deleted file mode 100644 index efead7c..0000000 --- a/config/dev.env.js +++ /dev/null @@ -1,6 +0,0 @@ -var merge = require('webpack-merge') -var prodEnv = require('./prod.env') - -module.exports = merge(prodEnv, { - NODE_ENV: '"development"' -}) diff --git a/config/index.js b/config/index.js deleted file mode 100644 index 9945b5d..0000000 --- a/config/index.js +++ /dev/null @@ -1,30 +0,0 @@ -// see http://vuejs-templates.github.io/webpack for documentation. -var path = require('path'); - -module.exports = { - build: { - env: require('./prod.env'), - assetsRoot: path.resolve(__dirname, '../dist'), - assetsSubDirectory: '', - assetsPublicPath: '/', - productionSourceMap: true - }, - dev: { - env: require('./dev.env'), - port: 8080, - proxyTable: {} - }, - umd: { - assetsRoot: path.resolve(__dirname, '../umd'), - assetsPublicPath: '/' - }, - homepage: { - env: require('./prod.env'), - entry: './docs/homepage/home.js', - assetsRoot: path.resolve(__dirname, '../site'), - assetsSubDirectory: '', - assetsPublicPath: '', - productionSourceMap: true - } -}; - diff --git a/config/prod.env.js b/config/prod.env.js deleted file mode 100644 index 773d263..0000000 --- a/config/prod.env.js +++ /dev/null @@ -1,3 +0,0 @@ -module.exports = { - NODE_ENV: '"production"' -} diff --git a/config/test.env.js b/config/test.env.js deleted file mode 100644 index 89f90de..0000000 --- a/config/test.env.js +++ /dev/null @@ -1,6 +0,0 @@ -var merge = require('webpack-merge') -var devEnv = require('./dev.env') - -module.exports = merge(devEnv, { - NODE_ENV: '"testing"' -})